当前位置:   article > 正文

vue-cli+vue3+vite+ts 搭建uniapp项目全过程(一)_uniapp用vite构建

uniapp用vite构建

unapp官方提供了cli 脚手架创建 uni-app 项目的文档

  • Vue3/Vite版要求 node 版本 18+、20+
  • 使用Vue3/Vite版创建不会提示选择模板,目前只支持创建默认模板
本文以vue3+vite+ts为例
 1、初始化项目
npx degit dcloudio/uni-preset-vue#vite-ts my-vue3-project

 执行完生成的文件结构如下:

然后执行 npm install 安装依赖

安装完依赖之后执行 npm run dev:mp-weixin 运行到微信小程序

2、uView安装
npm install uview-plus
3、安装sass-loadernode-sass

uview-plus依赖SCSS,您必须要安装此插件,否则无法正常运行。

安装sass-loader,注意需要版本10,否则可能会导致vue与sass的兼容问题而报错

npm add sass-loader@10.0.1 node-sass@4 --dev

安装sass

npm i sass -D

 安装dayjs

npm install dayjs

安装clipboard

npm install clipboard

 uview-plus使用

在项目src目录中的main.js中,引入并使用uview-plus的JS库,注意这两行要放在const app = createSSRApp(App)之后

  1. // main.js
  2. import uviewPlus from 'uview-plus'
  3. // #ifdef VUE3
  4. import { createSSRApp } from 'vue'
  5. export function createApp() {
  6. const app = createSSRApp(App)
  7. app.use(uviewPlus)
  8. return {
  9. app
  10. }
  11. }
  12. // #endif

引入uview-plus的全局SCSS主题文件 

在项目根目录的uni.scss中引入此文件。

  1. /* uni.scss */
  2. @import 'uview-plus/theme.scss';

引入uview-plus基础样式

App.vue首行的位置引入,注意给style标签加入lang="scss"属性

  1. <style lang="scss">
  2. /* 注意要写在第一行,同时给style标签加入lang="scss"属性 */
  3. @import "uview-plus/index.scss";
  4. </style>

配置easycom组件模式

此配置需要在项目src目录的pages.json中进行。

  1. uni-app为了调试性能的原因,修改easycom规则不会实时生效,配置完后,您需要重启HX或者重新编译项目才能正常使用uview-plus的功能。
  2. 请确保您的pages.json中只有一个easycom字段,否则请自行合并多个引入规则。
  1. // pages.json
  2. {
  3. "easycom": {
  4. "autoscan": true,
  5. // 注意一定要放在custom里,否则无效,https://ask.dcloud.net.cn/question/131175
  6. "custom": {
  7. "^u--(.*)": "uview-plus/components/u-$1/u-$1.vue",
  8. "^up-(.*)": "uview-plus/components/u-$1/u-$1.vue",
  9. "^u-([^-].*)": "uview-plus/components/u-$1/u-$1.vue"
  10. }
  11. },
  12. // 此为本身已有的内容
  13. "pages": [
  14. // ......
  15. ]
  16. }

typescript支持

在tsconfig.json中参考如下配置增加"uview-plus/types"

  1. {
  2. "compilerOptions": {
  3. "sourceMap": true,
  4. "baseUrl": ".",
  5. "paths": {
  6. "@/*": ["./src/*"]
  7. },
  8. "lib": ["esnext", "dom"],
  9. "types": [
  10. "@dcloudio/types",
  11. "uview-plus/types"
  12. ]
  13. },
  14. "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"]
  15. }

 uView使用

通过npm和下载方式的配置之后,在某个页面可以直接使用组件,无需通过import引入组件。

  1. <template>
  2. <up-button type="primary" text="确定"></up-button>
  3. </template>

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号