iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Vue3+TS+Vant3+Pinia怎么配置
  • 521
分享到

Vue3+TS+Vant3+Pinia怎么配置

2023-07-05 00:07:33 521人浏览 薄情痞子
摘要

本篇内容介绍了“vue3+TS+Vant3+Pinia怎么配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!推荐的IDE设置VS Code&

本篇内容介绍了“vue3+TS+Vant3+Pinia怎么配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

推荐的IDE设置

VS Code + Volar

键入支持。TS中的Vue导入

因为typescript无法处理的类型信息。vue导入,默认情况下,它们填充为通用vue组件类型。在大多数情况下,如果您不真正关心模板之外的组件道具类型,那么这很好。然而,如果你想得到实际的道具类型。vue导入,您可以通过以下步骤启用Volar的接管模式:

运行扩展:从VS代码的命令调色板中显示内置扩展,查找TypeScript和javascript语言功能,然后右键单击并选择禁用(工作区)。默认情况下,如果禁用默认的TypeScript扩展,则接管模式将自动启用。

通过从命令调色板运行Developer:Reload window重新加载VS代码窗口。

安装pnpm

#轻量级pnpm
稍微解释一下
pnpm的原理在于不会傻瓜式的无脑存储相应的副本,而是进行差异文件的比对,只会增加变化了的文件,相当于这些多个项目相同的部分都共享了一个版本的依赖。

这样的话,硬盘空间可以得到大量的缩减,同时加快了安装速度

说白了就是会比npm加载速度快很多
比如说安装一个依赖,就可以使用

npm install pnpm -g

你会发现比npm快的多的多。

pnpm install

一、安装vite

搭建vite

yarn create vite

安装依赖

npm i

启动项目

yarn dev

选择Vue3+TS的版本即可

二、安装pinia

npm add pinia@next

挂载Pinia

main.ts

import { createApp } from 'vue'import './style.CSS'import App from './App.vue'import {createPinia} from 'pinia'const pinia = createPinia()const app = createApp(App)// 挂载到 Vue 根实例app.use(pinia)createApp(App).mount('#app')

局部引入Pinia

import { defineStore } from 'pinia'

下面可以看个使用例子:

  • 可以在对应的src下创建store/module/useCountStore.ts文件

  • 具体内容如下:
    useCountStore.ts

import { defineStore } from 'pinia'//定义容器//参数1:容器的id,必须唯一,将来pinia会把所有的容器挂载到根容器//参数2:选项对象//返回值是一个函数,调用得到容器实列export const useMainStore=defineStore('main',{    //state类似于组件的data,用来存储全局状态的    //state必须是函数:这样是为了在服务端渲染的时候避免交叉请求导致的数据状态污染    //必须是箭头函数,这是为了TS更好的类型推导   state:()=>{   return{      count:100,      foo:'ber',      arr:[1,2,3]   }   },   //getters 类似于组件的computed,用来封装计算属性,有缓存功能   //和vuex中的getters没有区别   getters:{      // 方式一:这里的state就是上面的state状态对象,使用参数可自动推到出返回值的类型       count10(state){       return state.count+20       },      //方式二:getters也可使用this      //直接使用this,ts不会推导出返回值是什么类型,所以要手动标明返回值的类型      // 方式三:传递参数,但不使用参数,直接用this,获取值也可,自动推出返回值类型(不推荐使用)   },   //类似于组件的methods, 封装业务逻辑,修改state   actions:{      //注意不能使用箭头函数定义actions:因为箭头函数绑定外部this,会改变this指向      //actions就是 通过this返回当前容器实例      // 这里的actions里的事件接受参数      // 这里的num:number为自定义参数,需要声明参数类型      changeState(num:number){         // this.count++;         this.count+=num         this.foo='hello!'         this.arr.push(4)         // 同理,actions里也可使用$patch          this.$patch({})          this.$patch(state=>{})         //在此注意:patch和普通多次修改的区别在原理上的区别是         // 1.涉及到数据响应式和视图更新,多次修改,修改几次视图就更新就更新几次         // 2.patch 批量修改 视图只更新一次,更有利于性能优化      }   }})//使用容器中的state//修改 state//容器中的actions的使用

数据写好之后在组件中使用即可

<template>  <h4>Pinia基本使用</h4>  <p>{{mainStore.count}}</p>  <p>{{mainStore.arr}}</p>  {{mainStore.count10}}  <hr />  <p>解构mainStore后的渲染</p>  <p>{{count}}</p>  <p>{{foo}}</p>  <hr />  <p>    <van-button type="success" @click="handleChangeState">修改数据</van-button>  </p></template><script lang="ts" setup>import { useMainStore } from "../../store/module/useCountStore";import { storeToRefs } from "pinia";const mainStore = useMainStore();console.log(mainStore.count);//可以直接解构mainStore,但是这样是有问题的,这样拿到的数据不是响应式的,是一次性的,之后count和foo的改变这里是不会变的//Pinia其实就是把state数据都做了Reactive处理了//  const { count,foo}=mainStore//解决不是响应式的办法 官方的一个api storeToRefs// storeToRefs的原理是把结构出来的数据做ref响应式代理const { count, foo } = storeToRefs(mainStore);const handleChangeState = () => {  // 数据的修改  // 方式一:最简单的方式,直接调用修改  mainStore.count++;  //方式二:如果要修改多个数据,建议使用$patch 批量更新  // 方式三:更好的批量更新的函数:$patch是一个函数,这个也是批量更新  // 这里的state index.ts里的state  mainStore.$patch((state) => {    state.count++;    state.foo = "hello!";    state.arr.push(4);  });  //方式四:逻辑比较多的时候封装到actions中做处理  mainStore.changeState(10);};</script>

三、安装vant3

// 两种都可以npm i vantnpm i vant@next -s

安装插件

# 通过 npm 安装npm i unplugin-vue-components -D# 通过 yarn 安装yarn add unplugin-vue-components -D# 通过 pnpm 安装pnpm add unplugin-vue-components -D

这个插件可以自动按需引入组件

基于vite项目配置插件

在vite.config.ts中配置

import vue from '@vitejs/plugin-vue';import Components from 'unplugin-vue-components/vite';import { VantResolver } from 'unplugin-vue-components/resolvers';export default {  plugins: [    vue(),    Components({      resolvers: [VantResolver()],    }),  ],};

引入组件

在mian.ts中引入vant组件

import { createApp } from 'vue';import { Button } from 'vant';const app = createApp();app.use(Button);

四、安装router4

npm install vue-router

Vue3+TS+Vant3+Pinia怎么配置

router/index.ts配置内容如下:

import { createRouter, createWEBHistory,createWebHashHistory, RouteRecordRaw } from 'vue-router'import Home from '../view/Home.vue';const routes: Array<RouteRecordRaw> = [  {    path: '/',    name: 'index',    component: Home,  },]const router = createRouter({  history: createWebHashHistory(),   // history: createWebHistory(),  routes})export default router;

main.ts配置项

import App from './App.vue'import router from './router/index'app.use(router).mount('#app')

App.vue
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TOITHQne-1658887594763)(./src/assets/image/MDImg/router.png)]

五、安装axiOS

npm install axiospnpm install axios

这个封装可供参考
Vue3+TS+Vant3+Pinia怎么配置

Vue3+TS+Vant3+Pinia怎么配置
此处经过修改,以下方代码为准

 import axios from 'axios'// 创建axiosconst service = axios.create({  // baseURL: '/api',  baseURL: 'Http://xxx.xxx.xx.xxx/',  timeout:80000});// 添加请求拦截器service.interceptors.request.use(  (config:any) => {    let token:string =''//此处换成自己获取回来的token,通常存在在cookie或者store里面    if (token) {      // 让每个请求携带token-- ['X-Token']为自定义key 请根据实际情况自行修改      config.headers['X-Token'] = token         config.headers.Authorization =  + token            }    return config  },  error => {    // Do something with request error    console.log("出错啦", error) // for debug    Promise.reject(error)  })service.interceptors.response.use(  (response:any) => {   return response.data },     error => {   console.log('err' + error) // for debug   if(error.response.status == 403){     // ElMessage.error('错了')     console.log('错了');        }else{     // ElMessage.error('服务器请求错误,请稍后再试')     console.log('服务器请求错误,请稍后再试');   }   return Promise.reject(error) })export default service;

service.ts
Vue3+TS+Vant3+Pinia怎么配置

import {request} from '../request'; // 调用测试export function getTest(params:any) {    return request({      url: '/xxxx',//此处为自己请求地址      method: 'get',      data:params    })  }

之后在页面中调用

// 接口引入地址import { getTest} from "../utils/api/service";       getTest('放入params参数').then(response => {            console.log("结果", response);          })          .catch(error => {            console.log('获取失败!')          });

六、适配方案

postcss-pxtorem插件

用来将px转换成rem适配(意思就是你只需要填写对应的px值,就可以在页面上自动适配,不需要自己手动转rem。

npm install postcss-pxtorem

网上有很多人说这个需要新建什么postcss.config.ts文件。在vite中是自带了这种写法,所以只需要直接在vite.config.ts中填写相关配置就可以了。

amfe-flexible插件

设置基准值

npm i -S amfe-flexible

这两个插件是必备的,下面给出配置项

import { defineConfig } from 'vite'import vue from '@vitejs/plugin-vue'import Components from 'unplugin-vue-components/vite';import { VantResolver } from 'unplugin-vue-components/resolvers';import postcssImport from "postcss-pxtorem"// https://vitejs.dev/config/export default defineConfig({  plugins: [    vue(),    Components({      resolvers: [VantResolver()],    }),      ],  server:{    host: '0.0.0.0'  },  // 适配  css: {    postcss: {      plugins: [        postcssImport({          // 这里的rootValue就是你的设计稿大小          rootValue: 37.5,          propList: ['*'],        })      ]    }  }})

效果图:
Vue3+TS+Vant3+Pinia怎么配置

“Vue3+TS+Vant3+Pinia怎么配置”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Vue3+TS+Vant3+Pinia怎么配置

本文链接: https://www.lsjlt.com/news/348683.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++ 生态系统中流行库和框架的贡献指南
    作为 c++++ 开发人员,通过遵循以下步骤即可为流行库和框架做出贡献:选择一个项目并熟悉其代码库。在 issue 跟踪器中寻找适合初学者的问题。创建一个新分支,实现修复并添加测试。提交...
    99+
    2024-05-15
    框架 c++ 流行库 git
  • C++ 生态系统中流行库和框架的社区支持情况
    c++++生态系统中流行库和框架的社区支持情况:boost:活跃的社区提供广泛的文档、教程和讨论区,确保持续的维护和更新。qt:庞大的社区提供丰富的文档、示例和论坛,积极参与开发和维护。...
    99+
    2024-05-15
    生态系统 社区支持 c++ overflow 标准库
  • c++中if elseif使用规则
    c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
    99+
    2024-05-15
    c++
  • c++中的继承怎么写
    继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
    99+
    2024-05-15
    c++
  • c++中如何使用类和对象掌握目标
    在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
    99+
    2024-05-15
    c++
  • c++中优先级是什么意思
    c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
    99+
    2024-05-15
    c++
  • c++中a+是什么意思
    c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
    99+
    2024-05-15
    c++
  • c++中a.b什么意思
    c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
    99+
    2024-05-15
    c++
  • C++ 并发编程库的优缺点
    c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
    99+
    2024-05-15
    c++ 并发编程
  • 如何在 Golang 中备份数据库?
    在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
    99+
    2024-05-15
    golang 数据库备份 mysql git 标准库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作