uni-app基于vite和vue3创建并集成pinia实现数据持久化

news2024/11/24 11:43:03

一、uni-app基于Vite和Vue3创建并集成pinia实现数据持久化

文章目录

  • 一、uni-app基于Vite和Vue3创建并集成pinia实现数据持久化
    • 1.如何创建基于Vite和Vue3的uni-app项目?
    • 2.选择其中一个分支,就是一个脚手架
  • 二、以下都是基于vite-ts版本创建和配置
    • 1.目录结构
    • 2.启动命令【微信小程序】
  • 三、配置uni-app集成uview-plus
    • 1.npm安装方式
    • 2.由于使用了TS,则配置完uview-plus之后会报错
    • 3.又因为tsconfig.json中扫描.d.ts文件的路径如下
    • 4.此处选择自行创建文件解决
  • 四、集成pinia实现状态管理
    • 1.main.ts配置如下
    • 2.piniaStore配置
  • 五、配置pinia的数据持久化
    • 1.配置支持uni-app的pinia持久化插件
    • 2.main.ts完整配置
    • 3.别忘了TS的支持
      • 4.修改vite默认5173的端口号

1.如何创建基于Vite和Vue3的uni-app项目?

DCloud 官方Gitee仓库 https://gitee.com/dcloud/uni-preset-vue
在这里插入图片描述

Gitee官方仓库提供了各种版本的uni-app的脚手架,可以自行选择直接使用。

在这里插入图片描述

2.选择其中一个分支,就是一个脚手架

常用的有vite(vite+vue3+js)、vite-ts(vite+vue3+ts)、vue3(基于uni-app的vue3版本:webpack)
版本可以自行选择

二、以下都是基于vite-ts版本创建和配置

克隆项目

git clone https://gitee.com/dcloud/uni-preset-vue.git

在这里插入图片描述

1.目录结构

在这里插入图片描述

2.启动命令【微信小程序】

在这里插入图片描述

三、配置uni-app集成uview-plus

注意:如果是vue2的版本,选择uview-ui;如果是vue3的版本选择uview-plus

uview-ui官网 https://www.uviewui.com/
在这里插入图片描述
uview-plus官网 https://uiadmin.net/uview-plus/
在这里插入图片描述

注意:因为当前项目是基于vite+vue3的框架,所以选择使用uview-plus版本,又因为是从仓库克隆的,所以安装方式是脱离了Hbuilder X软件而使用VSCode开发,所以选择npm的方式安装!

1.npm安装方式

npm安装方式1 https://uiadmin.net/uview-plus/components/npmSetting.html
在这里插入图片描述
npm安装方式2 https://uiadmin.net/uview-plus/components/install.html#npm方式
在这里插入图片描述

2.由于使用了TS,则配置完uview-plus之后会报错

在这里插入图片描述

3.又因为tsconfig.json中扫描.d.ts文件的路径如下

在这里插入图片描述
所以,要么更改扫描路径,要么自行创建对应路径文件,配置解决。

4.此处选择自行创建文件解决

在这里插入图片描述
在src下创建typings文件夹,自定义.d.ts文件,加上一行如下声明,即可解决uview-plus引入报错问题;

declare module "uview-plus";

在这里插入图片描述

四、集成pinia实现状态管理

因为是集成的vite+vue3的uni-app项目,官方更新不是那么及时,所以pinia不能使用最新版本,需要降级:"pinia": "^2.0.33"

pinia官方文档 https://pinia.vuejs.org/zh/
在这里插入图片描述

npm i pinia@2.0.33 -S

1.main.ts配置如下

import { createSSRApp } from "vue";
import App from "./App.vue";
import uviewPlus from "uview-plus";
import * as Pinia from "pinia";

export function createApp() {
    const app = createSSRApp(App);

    app.use(uviewPlus);

    // 1.创建pinia的实例
    const pinia = Pinia.createPinia();
    // 2.注册到app实例中
    app.use(pinia);

    return {
        app,
        Pinia, // 3.必须导出Pinia
    };
}

2.piniaStore配置

import { defineStore } from "pinia";
import { ref } from "vue";

type AppStoreType = {
    count: number;
};

// 第一种写法
export const useAppStore1 = defineStore({
    id: "appStore",
    state: (): AppStoreType => ({
        count: 0,
    }),
});

// 第二种写法(推荐)
export const useAppStore2 = defineStore("appStore", {
    state: (): AppStoreType => ({
        count: 0,
    }),
    actions: {
        addCar(item: any) {}
    },
});
// 第三种写法
export const useAppStore3 = defineStore("appStore", () => {
    const count = ref(0);

    return {
        count,
    };
});

五、配置pinia的数据持久化

注意:虽然使用了vue3,但是不是最新的vue3,所以pinia也不是最新的pinia,不能使用官方提供的数据持久化的插件

pinia官方提供的持久化插件 https://prazdevs.github.io/pinia-plugin-persistedstate/zh/
在这里插入图片描述

1.配置支持uni-app的pinia持久化插件

pinia支持uni-app的持久化插件 https://www.npmjs.com/package/pinia-plugin-persist-uni
在这里插入图片描述

npm i pinia-plugin-persist-uni

在这里插入图片描述

2.main.ts完整配置

import { createSSRApp } from "vue";
import App from "./App.vue";
import uviewPlus from "uview-plus";
import * as Pinia from "pinia";
import piniaPersist from "pinia-plugin-persist-uni";

export function createApp() {
    const app = createSSRApp(App);

    app.use(uviewPlus);

    // 1.创建pinia的实例
    const pinia = Pinia.createPinia();
    pinia.use(piniaPersist);
    app.use(pinia);

    return {
        app,
        Pinia, // 2.必须导出Pinia
    };
}

3.别忘了TS的支持

在这里插入图片描述

import { defineStore } from "pinia";

type AppStoreType = {
    count: number;
};

export const useAppStore2 = defineStore("appStore", {
    persist: {
        enabled: true, // 开启持久化
        strategies: [
            {
                key: "appStore", // 持久化的key
                storage: window?.localStorage, // 持久化的方式,可以选择sessionStorage
            },
        ],
    },
    state: (): AppStoreType => ({
        count: 0,
    }),
    actions: {
        addCar(item: any) {},
    },
});

4.修改vite默认5173的端口号

vite.config.ts

import { defineConfig } from "vite";
import uni from "@dcloudio/vite-plugin-uni";

// https://vitejs.dev/config/
export default defineConfig({
    plugins: [uni()],
    server: {
        port: 8080 // 默认是5173
    }
});

如此,基于vite和vue3的uni-app小程序就创建完成啦,快去试试吧~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1194816.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

csharp写一个招聘信息采集的程序

csharp爬虫是一种用于自动化抓取网页内容的程序。它可以通过模拟人类浏览器的行为,自动访问网站并抓取所需的数据。csharp爬虫可以用于各种场景,例如数据挖掘、搜索引擎优化、竞争情报等。但是,使用csharp爬虫需要注意一些问题,例…

ElasticSearch7.x - HTTP 操作 - 文档操作

创建文档(添加数据) 索引已经创建好了,接下来我们来创建文档,并添加数据。这里的文档可以类比为关系型数 据库中的表数据,添加的数据格式为 JSON 格式 向 ES 服务器发 POST 请求 :http://192.168.254.101:9200/shopping/_doc 请求体内容为: {"title":"小…

conda修改虚拟环境名称

conda 修改虚拟环境名称 conda 不能直接更改名称,但是可以通过克隆环境解决 新建环境(克隆旧环境) conda create --name 新环境名 --clone 旧环境名 删除原环境 conda remove --name 旧环境名 --all 查看现有环境 conda env list conda i…

【IP-guard WebServer 远程命令执行漏洞复现(0day)】

文章目录 一、漏洞说明二、影响版本三、资产测绘四、漏洞复现五、修复建议 一、漏洞说明 IP-guard是由溢信科技股份有限公司开发的一款终端安全管理软件,旨在帮助企业保护终端设备安全、数据安全、管理网络使用和简化IT系统管理。 IP-guard Webserver远程命令执行漏…

麒麟V10系统下编译libcef_dll

目录 前言1、下载cef2、编译libcef_dll2.1 问题一 cmake版本太低2.2 问题二 无法识别的编译选项 -m64 3、总结 前言 本篇主要记录了在飞腾PC麒麟V10系统下编译libcef_dll时遇到的问题及解决方法。在Qt应用程序中使用QWebEngine加载HTML网页算是常规操作,但是涉及到…

QDockWidget组件的隐藏与显示(按钮控制)

本文内容包括: 1、控制按钮的点击效果美化; 2、用按钮控制QDockWidget组件的隐藏与显示; 参考前提:已有.ui文件、已有QDockWidget组件、已有一个控制QDockWidget组件的按钮 实现效果: DockWidget组件的隐藏与显示&…

贝锐蒲公英智慧运维方案:实现远程网络监控、管理、维护工业设备

为了提升运维效率,能够及时发现和响应设备的故障、异常和潜在问题。 越来越多的企业都在搭建“集中式”的远程智慧运维体系,以提高运维效率和降低成本。 但是,受限于网络,将不同地域的资源和信息进行整合,实现统一管理…

nodejs+vue+python+PHP+微信小程序-安卓-软件项目开发管理系统的设计与实现-计算机毕业设计

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性:…

【系统救援】 Ubuntu重启失败,报错:UNEXPECTED INCONSISTENCY; RUN fsck MANUALLY

问题定位及处理 查看错误信息:/dev/sda3 contains a file system with errors, check forced. /dev/sda3: Inodes that were part of a corrupted orphan linked list found. /dev/sda3: UNEXPECTED INCONSISTENCY; RUN fsck MANUALLY. (i.e., without -a or -p o…

c语言:用指针解决有关字符串等问题

题目1&#xff1a;将一个字符串str的内容颠倒过来&#xff0c;并输出。 数据范围&#xff1a;1≤len(str)≤10000 代码和思路&#xff1a; #include <stdio.h> #include<string.h> int main() {char str1[10000];gets(str1);//读取字符串内容char* p&str1[…

Pydantic:数据类型确认和解析神器

大家好&#xff0c;数据验证和解析是软件开发中的重要任务&#xff0c;特别是在处理用户输入或外部数据源时尤为重要&#xff0c;Python凭借其简洁性和多功能性&#xff0c;在这些任务中提供了各种库的帮助。在本文中将探讨Pydantic&#xff0c;介绍其特点&#xff0c;并提供一…

PSP - 蛋白质复合物结构预测 Template Pair 特征 Mask 可视化

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/134333419 在蛋白质复合物结构预测中&#xff0c;在 TemplatePairEmbedderMultimer 层中 &#xff0c;构建 Template Pair 特征的源码&#xff0c…

归并排序 图解 递归 + 非递归 + 笔记

前置知识&#xff1a;讲解019-算法笔试中处理输入和输出&#xff0c;讲解020-递归和master公式 (1)左部分排好序&#xff0c;右部分排好序&#xff0c;利用merge过程让左右整体有序(2)merge过程:谁小拷贝谁&#xff0c;直到左右两部分所有的数字耗尽(3)递归实现和非递归实现(4…

Nacos使用指南

Nacos使用指南 1.认识Nacos Nacos是SpringCloudAlibaba的一个组件&#xff0c;遵循SpringCloud规范 2.Nacos的优势 1.支持服务端主动检测服务提供者状态。临时实例采用心跳检测&#xff0c;非临时实例采用主动检测 2.Nacos支持服务列表变更消息推送&#xff0c;消息更加及…

设计模式之建造者(Builder)

用来构建复杂对象 分离复杂对象的构建和表示 同样的构建过程可以创建不同的表示 当有一个复杂的对象&#xff0c;构建它的时候&#xff0c;比较复杂 例如&#xff0c;构建一个对象&#xff0c;要传入50个参数&#xff0c;可以先构建part1&#xff0c;再构建part2…最后调用bu…

Mysql数据库 14.SQL语言 视图

一、视图的概念 视图&#xff1a;就是由数据库中一张或多张表根据特定的条件查询出的数据狗造成的虚拟表 二、视图的作用 安全性&#xff0c;简单性 三、视图的语法 语法 create view 视图表 as select_statement; 代码实现 #创建视图 将查询结果创建称为视图&#x…

华为ipsec vpn双链路主备备份配置案例

配置就是这配置&#xff0c;已查官方也是这样配置&#xff0c;意外是完成后不通&#xff0c;待以后处理&#xff01; FW_A配置&#xff1a; dhcp enable ip-link check enable ip-link name check_b destination 2.2.2.2 interface GigabitEthernet1/0/0 mode icmp next-hop …

vue2+elementui使用MessageBox 弹框$msgbox自定义VNode内容:实现radio

虽说实现下面的效果&#xff0c;用el-dialog很轻松就能搞定。但是这种简单的交互&#xff0c;我更喜欢使用MessageBox。 话不多说&#xff0c;直接上代码~ <el-button type"primary" size"mini" click"handleApply()" >处理申请</el-b…

实操创建属于自己的亚马逊云科技VPS服务:Amazon Lightsail

本文主要讲述如何独立创建自己的亚马逊云科技VPS服务&#xff0c;希望此文能帮助你对亚马逊云科技VPS服务也就是Amazon Lightsail&#xff0c;有个新的认识&#xff0c;对所使用的VPS有所帮助。 Amazon Lightsail是一款无论云计算的新手还是专家&#xff0c;都可通过其快速启动…

MySQL中UUID主键的优化

UUID&#xff08;Universally Unique IDentifier 通用唯一标识符&#xff09;&#xff0c;是一种常用的唯一标识符&#xff0c;在MySQL中&#xff0c;可以利用函数uuid()来生产UUID。因为UUID可以唯一标识记录&#xff0c;因此有些场景可能会用来作为表的主键&#xff0c;但直接…