百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

vue3移动端项目构建,vue3+vant+vite+axios+pinia+sass

toyiye 2024-06-21 12:41 27 浏览 0 评论

vue3:https://cn.vuejs.org/

vant:https://vant-contrib.gitee.io/vant/#/zh-CN

axios:https://www.axios-http.cn/docs/api_intro

vite:https://vitejs.cn/

pinia:https://pinia.vuejs.org/zh/

sass:https://blog.csdn.net/randy521520/article/details/131242242

前言:

本文主要讲解vue3移动端项目构建,在构建项目前请确保已安装node、yarn工具,node版本18+,此项目构建主要集成:axios、pinia、vant、sass、vite和vue3,其中还会介绍到如何跨页面传递数据、国际化配置、rem适配等功能

本文讲解的功能代码只是简要说明,完整代码可点击以下链接下载,下载后请先看README.md文档说明,已踩过大部分坑:

vue3+vant+vite+axios+pinia+sass完整版代码下载:【免费】vue3移动端项目搭建,vue3+vant+vite+axios+pinia+sass资源-CSDN文库

vue3+vant+vite+axios+pinia+sass+typescript完整版代码下载:【免费】vue3移动端项目构建TS,vue3+vant+vite+axios+pinia+sass+typescript资源-CSDN文库

vue3+antd+vite+pinia+axios+sass完整版代码下载:【免费】vue3移动端项目构建TS,vue3+vant+vite+axios+pinia+sass+typescript资源-CSDN文库

vue3+antd+vite+axios+pinia+sass+typescript完整版代码下载:【免费】vue3PC端项目构建TS,vue3+ant+vite+axios+pinia+sass+typescript资源-CSDN文库

一、初始化项目

  1. cmd打开终端工具,运行:yarn create vite

  1. 输入项目名称,键盘方向键选择vue

  1. 键盘方向键选择JavaScript

  1. 项目创建成功

  1. 开发者工具打开项目,打开开发者工具的终端,运行yarn install,安装package.json中的依赖包

  1. 修改package.json脚本中的dev为 vite --open,运行yarn dev,就会启动项目并在浏览器中自动打开,不加--open不会在浏览器中自动打开,项目初始化成功

  1. vite相关命令
vite [root]:启动开发服务器,可以指定一个根目录(可选)。
build [root]:构建生产环境的应用程序,可以指定一个根目录(可选)。
optimize [root]:预打包依赖项,用于优化构建性能。
preview [root]:本地预览生产环境的构建结果,可以指定一个根目录(可选)。
--open:启动开发服务器后自动打开默认浏览器并访问应用程序
--cors:启用 CORS(跨域资源共享)。
--strictPort:如果指定的端口已被占用,则退出。
--force:强制优化器忽略缓存并重新打包。
-c, --config <file>:使用指定的配置文件。
--base <path>:设置公共基础路径,默认为 /。
-l, --logLevel <level>:设置日志级别,可选值为 info、warn、error、silent。
--clearScreen:允许或禁用日志时的清屏操作。
-d, --debug [feat]:显示调试日志,可选参数为特定功能的名称。
-f, --filter <filter>:过滤调试日志的输出。
-m, --mode <mode>:设置环境模式。
-h, --help:显示帮助信息。
-v, --version:显示版本号。

二、集成vant

  1. 终端运行:yarn add vant,安装vant

  1. 修改mian.js,引入vant样式,注册组件

  1. 修改App.vue,会发现vant组件已经可以在页面显示

  1. 可以直接在页面导入组件使用,不用全局注册

三、vant组件按需引入组件样式

常规用法无论是全局注册组件,还是局部导入组件,还是需要手动导入,而且明明都是vant中的组件,局部导入和全局注册命名上是不一样的,对于强迫症的我说,看起来挺别扭。按需引入可以减小项目体积、避免全局污染、使项目代码更加精简和可维护等优点,借助unplugin-vue-components插件,可以避免手动导入组件

  1. 终端运行:yarn add unplugin-vue-components -D,安装unplugin-vue-components

  1. 修改vite.config.js

  1. 修改mian.js、App.vue,组件依然可以正常显示

  1. vant 中有个别组件是以函数的形式提供的,包括 Toast,Dialog,Notify 和 ImagePreview 组件,unplugin-vue-components无法解析自动注册组件,导致无法解析样式,解决办法就是在main.js中引入相关样式或者不使用函数形式,使用相关组件形式

四、集成sass

sass是css预处理器,可以声明变量、函数、嵌套等功能,可以减少重复的代码,使得样式表的结构更清晰、更易读。sass还内置了许多函数,处理颜色、数值等,也可以自定义函数扩展sass,还可以通过Mixin定义一组样式,并在需要的地方进行引用,可以避免重复的样式代码,并且方便进行样式的修改和维护

  1. 终端运行:yarn add sass -D,安装sass

  1. 在assets中新建scss>global.scss、scss>globalMixin.scss、scss>globalVar.scss、scss>iframe.scss,global.scss用于通用的样式、globalMixin.scss用于Mixin通用的样式、globalVar.scss用于全局变量、iframe.scss用于导出scss文件,修改vite.config.js,将iframe.scss文件引入到项目中

  1. 修改global.scss、globalMixin.scss、globalVar.scss,globalVar.scss中相关的颜色值尽量和vant保持一致,便于后面配置定制化主题时,使自己组件的样式和vant统一,如果不涉及和vant保持一致,可以根据设计写成固定值

  1. 修改App.vue,div样式使用了scss变量、Mixin函数、scss通用样式已生效

五、路由配置

  1. 终端运行:yarn add vue-router,安装vue-router

  1. 在src下新建pages>home.vue,把之前App.vue的代码复制到home.vue中,并在vite.config.js配置pages路径别名

  1. 在src下新建router.js,配置home页面路由,并在main.js中使用该路由

  1. 修改App.vue,页面显示正常,说明路由配置成功,router-view渲染路由页面、transition路由切换过渡效果、keep-alive在组件切换时保留组件的状态,避免重新渲染和销毁component

六、ConfigProvider定制化主题

  1. 在src下新建hooks>useTheme.js,并在vite.config.js配置路径别名,之所以采用useTheme.js配置主题,是为了写内联样式时可以使用一样的主题配置

  1. 修改App.vue,查看页面会发现主色都变成红色了,primaryColor会被编译成--van-primary-color

  1. 这样配置主题还能解决另外一个问题,之前已经配置按需加载,如果没有引入相关的组件,globalVar.scss中的--van-primary-color是没有值的,因为是按需加载,又没有用--van-primary-color相关的组件,所以--van-primary-color是不会加载的,修改App.vue注释掉ConfigProvider、home.vue注释掉van-button后会发现页面中没使用van-button,div的背景色是没有的

  1. 使用van-config-provider,就算页面没使用相关的组件--van-primary-color也是可以加载出来的,这里没使用themeVars,所以是默认的蓝色

七、集成postcss,适配

  1. 终端运行:yarn add postcss-px-to-viewport-8-plugin -D,安装postcss-px-to-viewport-8-plugin

  1. 在根目录上新建postcss.config.js,重新运行项目,会发现之前div中的px已转换为vw,vant框架内部定义的变量也转为vw

  1. 不使用postcss.config.js,修改vite.config.js也可以配置postcss

  1. 只使用postcss.config.js是无法转换内联样式中的像素,可以自己写个插件转换

  1. 在src下新建plugin>style-pxtovw-loader.js,并在vite.config.js中引入该插件,之所以匹配useTheme.js,是因为如果useTheme.js中有配置像素单位,写内联样式时用到里面的像素,里面的px是无法转换的,再看页面之前的16px已转为vw;也可以把插件中的px转换vw的方法封装成hook,内联样式直接调用hook就行

  1. 修改style-pxtovw-loader.js

八、集成pinia,状态管理

  1. 终端运行:yarn add pinia pinia-plugin-persist,安装pinia、pinia-plugin-persis

  1. 在src下新建store>pinia.js、store>initStore.js、store>useDemoStore.js,在vite.config.js配置路径别名,并在main.js中使用该配置

  1. 修改home.vue,使用useDemoStore,成功拿到userName,初始化的store是不会存在storage的

  1. 修改demoStore中userName为 李四,可以的调用useDemoStore中的updateState方法,这个方法需要自己写,更新完之后会发现storage中已持久化储存该数据

九、国际化配置

  1. 终端运行:yarn add vue-i18n,安装vue-i18n

  1. 在src下新建common>commonEnum.js,commonEnum.js公共枚举文件,并在vite.config.js中配置路径别名

  1. 在src下新建lang>en_us.js、lang>zh_cn.js、lang>index.js,用于创建国际化,并在main.js中使用该配置,在vite.config.js中配置路径别名,把语言配置存入localStorage是为了保证语言改变之后,刷新页面之后也可以使用之前改变后的语言

  1. 修改home.vue后,页面切换中英文都可以生效,刷新页面后之前切换的语言也不会改变

十、创建page.vue组件作为项目的页面组件

  1. 在components下新建layout>Page.vue,并把src/components在vite.config.js中配置路径别名

  1. 删除style.css,增加style.scss,并在main.js中引入该scss
  1. 修改home.vue,再看页面可以正常显示,这个组件除了是页面组件之外,还解决了之前transition的报警信息,之前的报警是因为transition只能有一个root节点,没有这个组件包括的时候van-button、div都是transition的root节点。这个组件目前只封装了导航、top、body、footer,后面可以根据需要增加下拉刷新、滚动加载、暂无数据、以及底部tab等扩展功能

十一、集成字体图标

  1. 字体图标集成以阿里icon为例,访问:https://www.iconfont.cn/ 图标库,搜索返回,任选一个图标加入购物车

  1. 去购物车中,选择下载代码

  1. 在assets下新建font文件,把下载好的字体图标解压到该文件,然后在style.scss中引入iconfont.css

  1. 修改Page.vue,增加返回图标

十二、集成axios

  1. 终端运行:yarn add axios,安装axios
  1. 在common下新增requests.js
  1. 修改home.vue,查看页面会发现已请求到数据;这只是简单的用法,至于项目中需要的加密、返回的结果、怎么去管理api等问题需要根据具体的项目去调整

十三、开发环境配置

  1. 在根目录下新建.env.development、.env.production

  1. 修改package.json中的脚本命令

  1. 在hook下新建useCommon.js

  1. 运行yarn dev重新启动项目

  1. 修改home.vue,成功拿到环境配置

十四、路由跳转

  1. 因为Page.vue是每个页面都能用到的,通过main.js注册成全局组件

  1. 在pages下新建三个页面:list.vue、add.vue、detail.vue,分别为列表页、添加页、详情页,并配置路由

  1. 给页面添加跳转:home>list>add >detail 或 home>list>detail,下图中演示了三种路由跳转传参的方式,第一种params传参:需要提前在路由上配置相关参数,跳转成之后url上会显示参数,页面刷新之后不会丢失;第二种query传参:不需要提前在路由配置参数,跳转成之后url上会显示参数,页面刷新之后不会丢失;第三种state传参,是通过window.history传参,页面刷新之后不会丢失;第一种第二种传参虽然页面刷新之后不会丢失,但是会显示在url上,如果传递一些隐私数据或大量的数据显然不合适,第三种页面刷新之后不会丢失,不会显示在url上可以传递隐私数据,不过获取时候是通过history获取的,对于我来说无论是什么跳转传参,获取参数时是希望通过同一种方式获取,觉得没关系的可以忽略,纯属个人习惯

  1. 修改Page.vue,返回上一页功能,返回上一页可以使用router.go(-1)、router.back()无论哪一种都是基于浏览器的返回,浏览器的返回缺点儿在于不能传参、根据跳转历史记录返回,如果home>list>detail这样跳转返回自然没问题,如果home>list>add >detail这样跳转就会导致从详情页返回时返回到add页面,正常业务数据添加成功,跳转到查看详情,在详情页大部分时返回的list页面,虽然可以通过router.go(-1),指定返回页面层数,但是路由跳转过多难免不出问题,而且在返回是无法传递参数,所以路由这块儿需要重新封装,弥补这些弱势

十五、路由封装

在刚才的路由跳转中,分析了一些路由跳转的弱势,而且路由的封装可以完善Page.vue的返回功能。可以参考微信小程序的路由跳转功能,通过消息事件发布和订阅(事件发射器)来封装路由,再由状态管理器储存路由。事件发射器有三个基本的功能:注册事件、移除事件、触发事件

  1. 在hooks下新建useEventEmitter.js

  1. 在根目录下创建tabBar.js,可使用该js扩展Page.vue组件增加tabbar功能
  1. 修改store>initStore.js,增加routerStore

  1. 在store下增加useRouterStore.js,目前只封装了navigateTo、navigateBack

  1. 修改router.js增加历史路由监听和路由跳转监听事件,去除list路由上的参数

  1. 修改Page.vue返回上一页

  1. 修改home.vue、list.vue、add.vue、detail.vue跳转

  1. 页面效果

十六、结语

本文只是大致讲了下vue3移动端项目搭建,具体的细节还是需要根据自己项目的需要进行调整。路由只封装了navigateTo、navigateBack,可以根据微信小程序路由api的逻辑https://developers.weixin.qq.com/miniprogram/dev/api/route/wx.switchTab.html 封装switchTab、reLaunch、redirectTo,如果有更好的方法可以忽略该路由封装,个人觉得小程序路由做的挺好。路径别名可配可不配,根据自己喜好就行

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码