Skip to content

txw2018/vue3-ts-uniapp-template

Repository files navigation

项目技术栈

uniapp : vue3 + ts + vite + axios + pinia + sass

其他插件:

  • uni_ui:官方提供的简易 ui 库
  • ucharts:一个兼容不同平台的 echarts

git 提交规范 相关文章

  • type: commit 的类型
  • feat: 新特性
  • fix: 修改问题
  • refactor: 代码重构
  • docs: 文档修改
  • style: 代码格式修改, 注意不是 css 修改
  • test: 测试用例修改
  • chore: 其他修改, 比如构建流程, 依赖管理.
  • scope: commit 影响的范围, 比如: route, component, utils, build...
  • subject: commit 的概述, 建议符合 50/72 formatting
  • body: commit 具体修改内容, 可以分为多行, 建议符合 50/72 formatting
  • footer: 一些备注, 通常是 BREAKING CHANGE 或修复的 bug 的链接.

环境变量

不同环境的请求接口放在项目根目录的 config 下,会根据不同的打包命令使用不同的接口,详细命令看 package.json qa1 qa2 qa3 qa4 均为内网测试 release 为外网测试 production 为正式环境

组件

  • area-picker 封装的省市区联动组件 使用最新的行政编码
  • lazy-image 二次封装 image 组件,统一处理 loading 跟图片加载失败状态

app 更新方案

ios 安卓
整包更新 去 appstore 更新 app 内更新
资源热更新 app 内更新 app 内更新

整包更新 资源热更新

项目结构

├─.commitlintrc.js          # commitlint配置文件
├─.env.development          # 环境变量
├─.env.production
├─.env.qa1
├─.env.qa2
├─.env.qa3
├─.env.qa4
├─.env.release
├─.eslintignore
├─.eslintrc.cjs             # eslint配置
├─.gitignore
├─index.html
├─package-lock.json
├─package.json
├─README.md
├─tsconfig.json             # ts配置
├─vite.config.ts            # vite配置
├─config                    # 不同环境变量配置
├─src
| ├─App.vue
| ├─env.d.ts
| ├─main.ts
| ├─manifest.json
| ├─pages.json
| ├─plugin.d.ts
| ├─uni.scss
| ├─utils
| | ├─request.ts
| | └validate.ts
| ├─types                   # 全局ts类型
| | └index.ts
| ├─svg
| | ├─home.svg
| | ├─icon
| | | └home.svg
| ├─store                   # 数据管理
| | └user.ts
| ├─static
| | └logo.png
| ├─pages                   # 路由页面
| | ├─my
| | | └index.vue
| | ├─index
| | | └index.vue
| ├─components              # 组件    ui组件放在base下面 业务组件放在components下
| | ├─base
| | | └svg-icon.vue
| ├─api                     # axios请求api
| | └home.ts
├─.vscode
| └settings.json
├─.husky                    # husky钩子(git提交钩子)
| ├─commit-msg
| ├─\_
| | ├─.gitignore
| | └husky.sh

修改组件样式

.home {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  ::v-deep .uni-navbar {
    width: 100vw;
  }
}

编写组件

方式一 template 模式

<script setup lang="ts">
import { computed, watch } from "vue";
const props = defineProps({
  title: { type: String, default: "Vue" },
  likes: { type: Number, default: 1 },
});
const newTile = computed(() => "hello" + props.title);
watch(
  () => props.likes,
  (newValue) => {
    console.log(newValue);
  }
);
</script>
<template>
  <view>
    <text>
      {{ newTile }}
    </text>
  </view>
</template>

方式二 render 模式(小程序不支持)

<script lang="ts">
import { defineComponent } from "vue";
export default defineComponent({
  props: {
    title: {
      type: String,
      default: "vue",
    },
  },
  setup(props) {
    // return <view>1111</view>;
  },
});
</script>

注册组件(easycom 模式)

文档

  • 第一步在 src/components/组件名/组件名.vue 的方式编写组件
  • 第二步在 src/components.d.ts 给组件添加 ts 智能提示

style 标签中使用 js 变量

<script setup>
const theme = {
  color: "red";
}
</script >
  /* or */
<script >
export default {
  data() {
    return {
      color: 'red'
    }
  }
}
</script >
page {
  color: v-bind(color);
  /* or */
  color: v-bind("theme.color");
}

About

一个vue3+ts+vite的uniapp模板

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published