经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
Vue3+TS+Vant3+Pinia(H5端)配置教程详解
来源:jb51  时间:2023/1/28 8:42:54  对本文有异议

该模板将帮助您开始使用Vue 3、Vite3.0中的TypeScript以及Pinia、Vant3进行开发。该模板使用Vue3,请查看文档了解更多教程。

推荐的IDE设置

VS Code + Volar

键入支持。TS中的vue导入

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

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

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

安装pnpm

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

这样的话,硬盘空间可以得到大量的缩减,同时加快了安装速度。看个图
请添加图片描述

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

  1. npm install pnpm -g

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

  1. pnpm install

一、安装vite

搭建vite

  1. yarn create vite

安装依赖

  1. npm i

启动项目

  1. yarn dev

选择Vue3+TS的版本即可

二、安装pinia

  1. npm add pinia@next

挂载Pinia

main.ts

  1. import { createApp } from 'vue'
  2. import './style.css'
  3. import App from './App.vue'
  4. import {createPinia} from 'pinia'
  5. const pinia = createPinia()
  6. const app = createApp(App)
  7. // 挂载到 Vue 根实例
  8. app.use(pinia)
  9. createApp(App).mount('#app')

局部引入Pinia

  1. import { defineStore } from 'pinia'

下面可以看个使用例子:

  • 可以在对应的src下创建store/module/useCountStore.ts文件
  • 具体内容如下:
    useCountStore.ts
  1. import { defineStore } from 'pinia'
  2.  
  3. //定义容器
  4. //参数1:容器的id,必须唯一,将来pinia会把所有的容器挂载到根容器
  5. //参数2:选项对象
  6. //返回值是一个函数,调用得到容器实列
  7. export const useMainStore=defineStore('main',{
  8. //state类似于组件的data,用来存储全局状态的
  9. //state必须是函数:这样是为了在服务端渲染的时候避免交叉请求导致的数据状态污染
  10. //必须是箭头函数,这是为了TS更好的类型推导
  11. state:()=>{
  12. return{
  13. count:100,
  14. foo:'ber',
  15. arr:[1,2,3]
  16. }
  17. },
  18. //getters 类似于组件的computed,用来封装计算属性,有缓存功能
  19. //和vuex中的getters没有区别
  20. getters:{
  21. // 方式一:这里的state就是上面的state状态对象,使用参数可自动推到出返回值的类型
  22. count10(state){
  23. return state.count+20
  24. },
  25.  
  26. //方式二:getters也可使用this
  27. //直接使用this,ts不会推导出返回值是什么类型,所以要手动标明返回值的类型
  28. /* count10():number{
  29. return this.count+20
  30. }, */
  31.  
  32.  
  33. // 方式三:传递参数,但不使用参数,直接用this,获取值也可,自动推出返回值类型(不推荐使用)
  34. /* count10(state){
  35. return this.count+20
  36. } */
  37. },
  38. //类似于组件的methods, 封装业务逻辑,修改state
  39. actions:{
  40. //注意不能使用箭头函数定义actions:因为箭头函数绑定外部this,会改变this指向
  41. //actions就是 通过this返回当前容器实例
  42. // 这里的actions里的事件接受参数
  43. // 这里的num:number为自定义参数,需要声明参数类型
  44. changeState(num:number){
  45. // this.count++;
  46. this.count+=num
  47. this.foo='hello!'
  48. this.arr.push(4)
  49.  
  50. // 同理,actions里也可使用$patch
  51. this.$patch({})
  52. this.$patch(state=>{})
  53.  
  54.  
  55. //在此注意:patch和普通多次修改的区别在原理上的区别是
  56. // 1.涉及到数据响应式和视图更新,多次修改,修改几次视图就更新就更新几次
  57. // 2.patch 批量修改 视图只更新一次,更有利于性能优化
  58. }
  59. }
  60. })
  61. //使用容器中的state
  62. //修改 state
  63. //容器中的actions的使用
  64.  
  65.  

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

  1. <template>
  2. <h3>Pinia基本使用</h3>
  3. <p>{{mainStore.count}}</p>
  4. <p>{{mainStore.arr}}</p>
  5. {{mainStore.count10}}
  6. <hr />
  7. <p>解构mainStore后的渲染</p>
  8. <p>{{count}}</p>
  9. <p>{{foo}}</p>
  10. <hr />
  11. <p>
  12. <van-button type="success" @click="handleChangeState">修改数据</van-button>
  13. </p>
  14. </template>
  15. <script lang="ts" setup>
  16. import { useMainStore } from "../../store/module/useCountStore";
  17. import { storeToRefs } from "pinia";
  18. const mainStore = useMainStore();
  19. console.log(mainStore.count);
  20. //可以直接解构mainStore,但是这样是有问题的,这样拿到的数据不是响应式的,是一次性的,之后count和foo的改变这里是不会变的
  21. //Pinia其实就是把state数据都做了reactive处理了
  22. // const { count,foo}=mainStore
  23.  
  24. //解决不是响应式的办法 官方的一个api storeToRefs
  25. // storeToRefs的原理是把结构出来的数据做ref响应式代理
  26. const { count, foo } = storeToRefs(mainStore);
  27.  
  28. const handleChangeState = () => {
  29. // 数据的修改
  30. // 方式一:最简单的方式,直接调用修改
  31. mainStore.count++;
  32.  
  33. //方式二:如果要修改多个数据,建议使用$patch 批量更新
  34.  
  35. // 方式三:更好的批量更新的函数:$patch是一个函数,这个也是批量更新
  36. // 这里的state index.ts里的state
  37. mainStore.$patch((state) => {
  38. state.count++;
  39. state.foo = "hello!";
  40. state.arr.push(4);
  41. });
  42.  
  43. //方式四:逻辑比较多的时候封装到actions中做处理
  44. mainStore.changeState(10);
  45. };
  46. </script>

写完后就可以使用了,具体使用教程可以参考官方文档Pinia官网

三、安装vant3

  1. // 两种都可以
  2. npm i vant
  3. npm i vant@next -s

安装插件

  1. # 通过 npm 安装
  2. npm i unplugin-vue-components -D
  3.  
  4. # 通过 yarn 安装
  5. yarn add unplugin-vue-components -D
  6.  
  7. # 通过 pnpm 安装
  8. pnpm add unplugin-vue-components -D
  9.  

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

基于vite项目配置插件

在vite.config.ts中配置

  1. import vue from '@vitejs/plugin-vue';
  2. import Components from 'unplugin-vue-components/vite';
  3. import { VantResolver } from 'unplugin-vue-components/resolvers';
  4.  
  5. export default {
  6. plugins: [
  7. vue(),
  8. Components({
  9. resolvers: [VantResolver()],
  10. }),
  11. ],
  12. };
  13.  

引入组件

在mian.ts中引入vant组件

  1. import { createApp } from 'vue';
  2. import { Button } from 'vant';
  3.  
  4. const app = createApp();
  5. app.use(Button);
  6.  

四、安装router4

  1. npm install vue-router

请添加图片描述

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

  1. import { createRouter, createWebHistory,createWebHashHistory, RouteRecordRaw } from 'vue-router'
  2. import Home from '../view/Home.vue';
  3. const routes: Array<RouteRecordRaw> = [
  4. {
  5. path: '/',
  6. name: 'index',
  7. component: Home,
  8. },
  9. ]
  10. const router = createRouter({
  11. history: createWebHashHistory(),
  12. // history: createWebHistory(),
  13. routes
  14. })
  15. export default router;

main.ts配置项

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

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

五、安装axios

  1. npm install axios
  2. pnpm install axios

这个封装可供参考
请添加图片描述

请添加图片描述
此处经过修改,以下方代码为准

  1. import axios from 'axios'
  2.  
  3. // 创建axios
  4. const service = axios.create({
  5. // baseURL: '/api',
  6. baseURL: 'http://xxx.xxx.xx.xxx/',
  7. timeout:80000
  8. });
  9.  
  10. // 添加请求拦截器
  11. service.interceptors.request.use(
  12. (config:any) => {
  13. let token:string =''//此处换成自己获取回来的token,通常存在在cookie或者store里面
  14. if (token) {
  15. // 让每个请求携带token-- ['X-Token']为自定义key 请根据实际情况自行修改
  16. config.headers['X-Token'] = token
  17. config.headers.Authorization = + token
  18. }
  19. return config
  20. },
  21. error => {
  22. // Do something with request error
  23. console.log("出错啦", error) // for debug
  24. Promise.reject(error)
  25. }
  26. )
  27.  
  28. service.interceptors.response.use(
  29. (response:any) => {
  30. return response.data
  31. }, /* */
  32. error => {
  33. console.log('err' + error) // for debug
  34. if(error.response.status == 403){
  35. // ElMessage.error('错了')
  36. console.log('错了');
  37. }else{
  38. // ElMessage.error('服务器请求错误,请稍后再试')
  39. console.log('服务器请求错误,请稍后再试');
  40. }
  41. return Promise.reject(error)
  42. }
  43. )
  44. export default service;
  45.  
  46.  

service.ts
请添加图片描述

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

之后在页面中调用

  1. // 接口引入地址
  2. import { getTest} from "../utils/api/service";
  3.  
  4. /* 调用接口 */
  5. getTest('放入params参数').then(response => {
  6. console.log("结果", response);
  7. })
  8. .catch(error => {
  9. console.log('获取失败!')
  10. });

六、适配方案

postcss-pxtorem插件

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

  1. npm install postcss-pxtorem

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

amfe-flexible插件

设置基准值

  1. npm i -S amfe-flexible

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

  1. import { defineConfig } from 'vite'
  2. import vue from '@vitejs/plugin-vue'
  3. import Components from 'unplugin-vue-components/vite';
  4. import { VantResolver } from 'unplugin-vue-components/resolvers';
  5. import postcssImport from "postcss-pxtorem"
  6. // https://vitejs.dev/config/
  7. export default defineConfig({
  8. plugins: [
  9. vue(),
  10. Components({
  11. resolvers: [VantResolver()],
  12. }),
  13. ],
  14. server:{
  15. host: '0.0.0.0'
  16. },
  17. // 适配
  18. css: {
  19. postcss: {
  20. plugins: [
  21. postcssImport({
  22. // 这里的rootValue就是你的设计稿大小
  23. rootValue: 37.5,
  24. propList: ['*'],
  25. })
  26. ]
  27. }
  28. }
  29. })
  30.  

效果图:
请添加图片描述

到此这篇关于Vue3+Vant3+Pinia(H5端)配置教程详解的文章就介绍到这了,更多相关Vue3+Vant3+Pinia(H5端)配置教程内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号