更新记录
1.0.1(2022-10-10) 下载此版本
1010
- 兼容微信小程序端,优化框架内容,优化界面样式
- 欢迎关注项目仓库,获取最新代码,一起学习交流:https://gitee.com/mrthinco/share-bbs
平台兼容性
Vue2 | Vue3 |
---|---|
√ | × |
App | 快应用 | 微信小程序 | 支付宝小程序 | 百度小程序 | 字节小程序 | QQ小程序 |
---|---|---|---|---|---|---|
app-vue | × | √ | × | × | × | × |
钉钉小程序 | 快手小程序 | 飞书小程序 | 京东小程序 |
---|---|---|---|
× | × | × | × |
H5-Safari | Android Browser | 微信浏览器(Android) | QQ浏览器(Android) | Chrome | IE | Edge | Firefox | PC-Safari |
---|---|---|---|---|---|---|---|---|
× | × | × | × | √ | × | √ | × | × |
[TOC]
一、项目介绍
- 项目描述:“share-bbs”是一套采用“uni-App”开发的分享社交论坛,兼容Android、IOS、微信小程序。
- 代码说明:此项目为纯前端项目,不含后端、数据库等(方便本地运行、学习、复用)。前端框架:uni-app,vue.js,uViewUI。
- 仓库地址:[社交论坛] https://gitee.com/mrthinco/share-bbs
- 项目展示:
二、目录说明
2.1 目录
share-bbs
├─ components // 组件库
├─ com-* // 公共组件
├─ 页面名称-* // 页面组件
└─ uni-* // uni组件
├─ pages // 页面
├─ index // 首页模块
├─ news // 动态模块
├─ paper // 小纸条模块
└─ mine // 我的模块
├─ static // 静态资源, 存放应用引用的本地静态资源(如图片、视频等)的目录,注意:静态资源只能存放于此
├─ css // css样式库
├─ thinco.css:样式库(自定义)
├─ animate.css:动画库(第三方)
├─ iconfont.css:自定义图标库(第三方)
└─ uni.css: 官方UI库(第三方)
├─ font // 字体文件
└─ img // 图片文件
├─ utils // js工具库
├─uni_modules // 存放[uni_module](/uni_modules)
├─platforms // 存放各平台专用页面的目录
├─nativeplugins // App原生语言插件
├─hybrid // App端存放本地html文件的目录
├─wxcomponents // 存放小程序组件的目录
├─unpackage // 非工程代码,一般存放运行或发行的编译结果
├─AndroidManifest.xml // Android原生应用清单文件
├─main.js // Vue初始化入口文件
├─App.vue // 应用配置,用来配置App全局样式以及监听 应用生命周期
├─manifest.json // 配置应用名称、appid、logo、版本等打包信息
├─pages.json // 配置页面路由、导航条、选项卡等页面类信息
└─uni.scss // 这里是uni-app内置的常用样式变量
2.2 pages 模块/页面
- home 首页模块
- mine 我的模块
- news 动态模块
- paper 小纸条模块
2.3 components 组件
2.3.1 组件命名规范
- 组件名称:小驼峰,尽量语义化,如:orderList
- 组件文件:组件名称/组件名称.vue,一个组件对应一个文件夹,该文件夹下可以有多个类型的文件(如:js、img、css等)。如:
orderList/orderList.vue
2.3.2 组件存放规范
- uni-ui组件或者三方组件直接存放为:
components/uni-*
(遵循:easycom规则)
在使用 uni-ui 的时候,只要uni-ui组件 安装在项目的 components 目录下,并符合 components/组件名称/组件名称.vue 目录结构。就可以不用引用、注册,直接在页面中使用 uni-ui 组件。 - 自定义公共复用组件存放为:
components/com*/com*.vue
(遵循:easycom规则)
这里存放自定义复用组件,方便大家开发和复用、共享。如果要修改,uni-ui组件,也建议复制粘贴到这里,然后自定义修改,避免去uni-ui中直接修改,因为后面uni官方组件升级后会导致之前的自定义代码丢失。 - 自定义非公共组件存放到:
当前页/cpns
,因为有的页面组件,其他页面根部就不会复用到,只是为了让主页面代码简洁和便于维护,那么这些组件,应该直接放到当前页下的cpns
文件夹中,独立维护。
2.3.3 组件说明规范
每个自定义组件,组件用法、参数描述应该简单、清晰,应该在组件代码的<script>
标签内的第一行备注好:组件名称、组件描述、开发人员、组件参数等,因为时间可以淡忘一切,当然也可以让你淡忘掉之前你为什么要传这个参数。
<script>
/*
* LoadMore 加载更多
* @description 用于列表中,做滚动加载使用,展示 loading 的各种状态
* @author 杰伦
* @property {String} status = [more|loading|noMore] loading 的状态
* @value more loading 前
* @value loading loading 中
* @value noMore 没有更多了
* @property {Number} iconSize 指定图标大小
*/
</script>
2.4 static 静态资源
static/font
字体文件static/img
图片文件- 建议图片能够放后端或者云存储的尽量就别放前端,减少包体积和优化加载速度 。
- 图片如果是复用的图片,不属于某个页面独有的图片,直接放此目录。
- 图片如果属于某个功能模块独有的,需要建立一个和模块名称同名的文件夹,再存于文件夹下。如:
static/img/order
订单模块的图片。
static/css
css样式库- /css/uni.css: 官方UI库(第三方)
- /css/animate.css:动画库(第三方)
- /css/iconfont.css:自定义图标库(第三方)
- /css/thinco.scss:样式库(自定义)
2.5 store vuex缓存
我们采用分模块来管理各个vuex子模块,便于项目的维护和整合。
index.js
此文件是入口文件,方便整合和引入vuex模块modules/user.js
此文件是用户信息相关vuex模块
三、配置插件
- pages.json文件
因为有的页面取消了导航栏,导致没法直观的辨别页面是哪个页面,做啥的。
- 每个页面配置项,顶部应该备注该页面说明。
- 特别的参数项,应该备注参数说明。
{ // 分组选择 "path": "pages/group/group-check-spec", "style": { "navigationStyle": "custom", // 取消本页面的导航栏 "backgroundColor": "transparent", "app-plus": { "animationType": "fade-in", // 设置fade-in淡入动画,为最合理的动画类型 "background": "transparent", // 背景透明 "backgroundColor": "rgba(0,0,0,0)", // 背景透明 "popGesture": "none" // 关闭IOS屏幕左边滑动关闭当前页面的功能 } } }
四、命名规范
4.1 文件命名
.vue/.css/.js文件命名采用小驼峰,尽量语义化,如:userList.vue
4.2 CSS命名规范
- class、id命名采用小写字母加中划线,尽量语义化,前缀是类型,后面是操作。如:提交按钮
btn-submit
。
4.3 JS命名规范
- js函数命名采用小驼峰,尽量语义化,如:
parseStartTag
。
五、版本规范
- 版本名称:2.220815.1
- 版本号:22208151
- 从左往右数字命名说明:
- 第一位:2,表示当前大迭代版本号:2版本
- 第二至七位:220815,表示当前的发版日期:22年08月15日
- 第八位:1-9,表示本次上线版本的上架审核次数,默认为1,重新上架一次递增1,最高为9 *【注意】:版本号和版本名称是对应关系,版本名称用点号分割
六、代码提交
feat 增加新功能
fix 修复问题/BUG
style 代码风格相关无影响运行结果的
perf 优化/性能提升
refactor 重构
revert 撤销修改
test 测试相关
docs 文档/注释
chore 依赖更新/脚手架配置修改等
workflow 工作流改进
ci 持续集成
types 类型定义文件更改
wip 开发中