关于uniapp简单模板封装想法

背景

因公司业务多是支付宝、微信平台的H5和小程序,为避免需要熟悉多个平台的写法,且降低开发成本,选用了uniapp作为基础框架来开发各个平台的项目。(因为公司成员多数熟悉而选取uniapp,如果是react为主,可借鉴taro

适用场景

公司小型项目投放平台多且杂,需统一代码风格和技术框架时,可选取。 基本功能包括:弹窗+简易请求封装

技术选型:uniapp+vue3+pinia+axios
git地址:

基本目录结构

主要功能用法

request

介绍

uniapp中提供了api --> uni.request来请求,但因使用axios较多,习惯其用法,所以在本模板中引用了axios作为主要的请求库。简易封装了axios,额外扩展了_loading,_retryTimes,onError等参数,配置动态路径等功能,其余用法与axios一致。(不追求过度封装,一切从简,避免理解成本,且因封装而失去了axios的特性。)

主要代码封装在./src/request中,具体的api定义在./src/apis中,按具体模块划分即可。

自定义扩展建议:仅修改axios中定义的拦截器,修改成对应接口所需的响应拦截,不做过多修改。

使用

代码

PS:request方法为创建的axios实例,主要通过上述代码实现额外的扩展能力,如请求loading(_loading)、自定义异常(onError)处理

dialog

介绍

因为基本的营销项目中基本都会用到弹窗,简单封装了基本的弹窗组件,提供了弹窗的显示层级,打开、关闭动画,打开/关闭弹窗参数传递等的功能。

使用

定义组件: 使用全局组件DailogWrapper作为父组件, NAME为弹窗命名,必须定义。里面编写弹窗具体内容。 参数介绍:

  • visible: 是否显示弹窗;
  • openPayLoad: 打开弹窗传入的参数;
  • close: 关闭弹窗的方法;

挂载弹窗: 在使用的页面引入定义的弹窗组件(或将弹窗组件挂载全局)

打开弹窗:通过通用的useDialogStore获得openDialog方法: const res = await openDialog(dialogName, openPayLoad, immediate) 参数介绍: dialogName: 弹窗组件定义的NAME,必传 openPayLoad:传递给弹窗的属性,可为任意数据结构,按需传递 immediate: 是否立刻打开弹窗,默认为false。因为弹窗有队列任务,在关闭弹窗前,打开另外一个弹窗会等待该弹窗关闭时显示。

res: openDialog返回一个promise,reslove的信息为弹窗中调用close传递的参数。常用于接收信息收集弹窗。 设计成此模式是为了避免弹窗间的信息传递需要通过props和emit来传输。

go 复制代码
// 弹窗组件
import { useDialogStore } from '@/store/useDialogStore'
const { close } = useDialogStore()

close(dialogName, closePayload) // closePayload为关闭参数,为openDialog的返回信息

// 页面组件
const res = await openDialog(dialogName, openPayLoad) // 此时的res=== closePayLoad

代码

具体参考git中的src/store/useDialogStoresrc/components/DialogWrapper中的代码。

其他

  • 自定义了一个vite的plugin用于消除uni打包H5后会自动加载一张cdn的图片,会导致首屏渲染慢。

结尾

主要简单总结了对了uniapp框架简单封装的一些基础用法,如果有需要对授权、图表等通用功能的开发或者当前实现功能的实现细节,可评论区留言讨论。

相关推荐
wadesir1 天前
Nginx负载均衡代理协议详解(从零开始搭建高可用Web服务)
前端·nginx·负载均衡
秋氘渔1 天前
Vue 3 组合式写法:侦听器 watch 和 watchEffect 的区别及使用技巧
前端·javascript·vue.js·watch·watcheffect
想睡八个小时1 天前
已包含的文件名 “a.vue“ 仅大小写与文件名 “A.vue“ 不同
前端·vscode
The_era_achievs_hero1 天前
Echarts
前端·javascript·echarts
涔溪1 天前
Vite 和 Webpack 这两款主流前端构建工具的核心区别,包括它们的设计理念、工作机制和实际使用体验上的差异。
前端·webpack·vite
0思必得01 天前
[Web自动化] 开发者工具元素(Elements)面板
运维·前端·自动化·web自动化·开发者工具
遇到困难睡大觉哈哈1 天前
Harmony os ——ArkTS 语言笔记(五):泛型、空安全与可选链
前端·笔记·安全·harmonyos·鸿蒙
八哥程序员1 天前
你真的理解了 javascript 中的原型及原型链?
前端·javascript
冴羽1 天前
10 个 Nano Banana Pro 专业级生图技巧
前端·人工智能·aigc
7ayl1 天前
Vue3 - runtime-core的渲染器初始化流程
前端·vue.js