创建
pnpm create vite安装提示选择vue+ts模版
ElementUI
安装
pnpm install element-plus
按需导入
安装依赖
pnpm install -D unplugin-vue-components unplugin-auto-import
vite中引入
data:image/s3,"s3://crabby-images/1a91f/1a91fa010d9c6c76bbafe68c877107b354a19350" alt=""
反馈组件样式单独引入
@import "element-plus/theme-chalk/el-loading.css";
@import "element-plus/theme-chalk/el-message.css";
@import "element-plus/theme-chalk/el-notification.css";
@import "element-plus/theme-chalk/el-message-box.css";
别名
安装(path和__dirname类型错误)
pnpm install @types/node
tsconfig添加paths项(智能提示)
data:image/s3,"s3://crabby-images/52ba4/52ba4a7037ac3b5532914a17005d4b8a34c03280" alt=""
配置
data:image/s3,"s3://crabby-images/31fbf/31fbf1db336c481f5caedda5985594455021f867" alt=""
vue-router
安装
pnpm install vue-router@4
定义
data:image/s3,"s3://crabby-images/2eb55/2eb55d8517f517dc2d847dd59a2001393d04dde3" alt=""
注册
data:image/s3,"s3://crabby-images/93c61/93c616d631c09e6b47910bfce984907af2144659" alt=""
pinia
作为vue3配套的状态管理工具,pinia应该是首选的,不过我这是新项目,且比较明确用不到,就不安装了
可参考这篇文章
环境变量
设置
data:image/s3,"s3://crabby-images/65c0a/65c0abd8acef475657821d14770873fd0f9c4574" alt=""
使用
data:image/s3,"s3://crabby-images/f04f0/f04f00efe76961481879d0f8fe30b41dc4378de8" alt=""
axios
安装
npm install axios
配置
data:image/s3,"s3://crabby-images/4fbdb/4fbdba6e39f42351717b2190a6e8242374ad9084" alt=""
封装
data:image/s3,"s3://crabby-images/382bc/382bce89faeb252fd3aafdfedee6ee1736c4e8c4" alt=""
使用
data:image/s3,"s3://crabby-images/77d10/77d10c1182abc092f60a131650c50caf68f4ed47" alt=""
css
less
vite内置了less支持,只需要install它:pnpm i less -D
PostCSS
PostCSS是一款使用JavaScript插件对CSS实现转换的工具,可以使用它进行css操作,比如为兼容性差的属性添加浏览器前缀等“脏活”、“累活”,vite中也内置进行了支持,只需要安装对应的处理插件即可
postcss-import:智能寻址
postcss-preset-env:浏览器兼容前缀
data:image/s3,"s3://crabby-images/a1870/a1870ffd690fdb1d48bf2436c3176e736592371a" alt=""
代码规范
eslint
安装
pnpm install eslint
创建配置文件
npx eslint --init
修改配置文件(更多规则)
data:image/s3,"s3://crabby-images/dc199/dc1999e3abd46bac907311bc984c7c7ff3e52cfe" alt=""
配置vscode
安装eslint插件,找到其扩展设置,选择在setting.json中编辑
data:image/s3,"s3://crabby-images/67bd6/67bd61a81909c1de15a4376b7784a792f8aa87ed" alt=""
配置如下
data:image/s3,"s3://crabby-images/d3fda/d3fdad87b663dfb17519a845322c9f372dde607d" alt=""
vite-plugin
安装
pnpm i vite-plugin-eslint -D
使用
data:image/s3,"s3://crabby-images/f8d9d/f8d9dfa4d2e167ef3c162c666ca8fb3fe1a721ae" alt=""
效果
data:image/s3,"s3://crabby-images/b7d2e/b7d2eff0a478cd7b2632bf5fd8f7ecfcbe0ff63d" alt=""
跨级通信
vue3已经移除了eventbus,需要借助第三方库,我这里找了一个,虽然其核心能力是用来操作localStorage的,但是其提供了:加解密、批量操作、过期时间、命名空间、数据变化侦听等特性,其中的watch接口和postMessage接口即可用于实现跨级通信
为什么要用
说到底是懒,如果不跨级
则需要在子组件进行注册
data:image/s3,"s3://crabby-images/a1fc1/a1fc19835aad1983ba807d359aa7ca42e7f36964" alt=""
然后做出抛事件的动作
data:image/s3,"s3://crabby-images/9c152/9c15228f89ef5b642cea48fb6aa3196abe241f14" alt=""
然后在父组件进行监听
data:image/s3,"s3://crabby-images/0e01f/0e01fc914b5933cee9adb7f0a6354873654d484d" alt=""
我的页面比较复杂,需要跨好几个组件做通信,因此,上边的步骤需要在每一个组件中定义并相互传递,如下
data:image/s3,"s3://crabby-images/ecd51/ecd51aa451713ecdafb8f9c5c3db728f8731e1ad" alt=""
使用后,只需要在d组件抛出消息
data:image/s3,"s3://crabby-images/0db66/0db6699c8554493f5d38f516c9449bb65ba6992b" alt=""
然后在a组件监听即可
data:image/s3,"s3://crabby-images/4ce6b/4ce6b6f4771ef09aa5fc3333515b351931c92794" alt=""
其实,个人觉得,最好用的不是这个功能,而是其实现了类似“离线消息”的功能,如果消息发送的组件不在页面中,则该库会将消息滞留,并在对应组件挂载时触发
生产构建
生产构建每个人的可能都不一样,但一般来说,都要根据发布后的位置去改动base选项,但是由于vite中的vite.config.ts中不支持process.env.NODE_ENV这样的方式,故一般需要定义环境文件
data:image/s3,"s3://crabby-images/68b5c/68b5cf3ed5e248537a228881db32edf95aead0ec" alt=""
然后在vite.config.ts中使用loadEnv进行加载
data:image/s3,"s3://crabby-images/7d7f5/7d7f52f61bf229775223c9b3805d991e818b186c" alt=""
cjs文件的加载
按照网上的说法,基本都是利用commonjs和transform-reauire插件来实现,但是我试了,是无效的,最终尝试后,发下使用动态import是可以的
data:image/s3,"s3://crabby-images/5f4e2/5f4e212ca325866dfecd073cd0a48ee112593364" alt=""
其他相关文章
网友评论