vue 项目其他规范
列表
- vuex数据管理
* 数据模块化:vuex数据管理-数据模块化- 数据适配:vuex数据管理-数据适配
- 数据共享:vuex数据管理-数据共享
- 路由优化
- keep-alive组件设置
- 保留滚动位置
链接:vue路由管理-保留滚动位置功能、按需加载模块名自定义
- webpack配置
- 按需加载包名称自定义
链接:vue路由管理-保留滚动位置功能、按需加载模块名自定义
- 按需加载包名称自定义
- z-index叠层规范
- 基础布局的唯一性
- 组件的相关规范
z-index叠层规范
- lever1:普通content:1-99;
- lever2:header、footer、广告、页面tips等在内容之上,但又与内容相关性较大的;层:100-199;
- lever3:返回顶部等页面工具类:200-299;
- lever4:popup、picker等浮在页面上的操作层:300-399;
- lever5:loading:400-499;
- lever6: toast等直接遮罩在页面上的warning、error信息:500-599。
基础布局
结构
- .page
- header
- footer
- content
规范
每个页面仅允许一组基础布局,这为组件加载、交互、分层提供挂载、容器等基础。
原因
如果出现多套,将会影响公共组件引入的准确性和灵活性;也会影响功能的扩展等。
示例:totop组件
从引入组件的角度上看,作为一个基础浮动的工具组件,不应该关注实际业务及根插销,直接动态加载到基础布局当中即可。如果有多个嵌套的基础布局,将需要更多的代码,来辨别其插入点,也会失去灵活性,所以从组件的角度,唯一布局很重要。
从功能角度上看,它需要监控页面的滚动位置,在这种布局下,其需要监控content的位置情况,如果出现多个基础布局,将影响功能的使用。
组件的相关规范
加载方式
a、业务组件:可根据业务需求选择相应加载方式;
b、基础组件:尽量使用动态加载的方式,如popup、pick、loading这些浮层组件。其优势如下:
- 可以对使用者(开发人员)屏蔽加载点;
- 防止叠层错乱(业务组件引入基础浮层组件,如果非动态加载,浮层将于内容层交错,导致样式叠层错乱,要做额外的hack等);
- 有利于单页跳转时,组件的统一清除。
数据流
- a、基础组件:使用props加载数据,不关注业务;
- b、业务组件:抽象业务组件的业务范围,抽象数据结构,从vuex中进行取值,加强vuex数据的复用及组件的复用。
如何区分业务组件和基础组件:以地址picker为例。其首先是基础的picker组件,可实现多列滚动,每次滚动都会产生一个唯一的结果数组,确认以后,返回该结果数组。该基础picker组件可以扩展成动态请求数据的地址picker,也可以是固定值的多级picker,到底需要哪种,就与业务相关。因此,地址picker,是对基础组件picker的扩展,其包含数据流的存取过程,及数据流的交互,异步请求等。
组件升级
- 接口:对于公共组件,多人的调用的业务组件,需要做到旧接口的兼容。
- 兼容方式:提供一个新旧接口交替期,在该时期,新旧接口并存,开发者将组件往新的接口上迁移,迁移完成之后,组件设计者,再将旧接口移除。
叠层的定义
公共组件,可以根据给出的z-index规范,给出组件的z-index叠层id;但其取值尽量在该组件类型叠层规范数值范围的中间值,便于同类型业务组件的向下向上叠层处理。
vue 项目其他规范的更多相关文章
- 团队开发前端VUE项目代码规范
团队开发前端VUE项目代码规范 2018年09月22日 20:18:11 我的小英短 阅读数 1658 一.规范目的: 统一编码风格,命名规范,注释要求,在团队协作中输出可读性强,易维护,风格一致 ...
- 【转载】Vue项目中的文件/文件夹命名规范
文件或文件夹的命名遵循以下原则: index.js 或者 index.vue,统一使用小写字母开头的(kebab-case)命名规范 属于组件或类的,统一使用大写字母开头的(PascalCase)命名 ...
- Vue项目中的文件/文件夹命名规范
Vue项目中的文件/文件夹命名规范 0.2262018.09.21 16:01:09字数 820阅读 6979 文件或文件夹的命名遵循以下原则: index.js 或者 index.vue,统一使用小 ...
- 手把手教你搭建规范的团队vue项目,包含commitlint,eslint,prettier,husky,commitizen等等
目录 1,前言 2,创建项目 2,安装vue全家桶 3,配置prettier 4,配置eslint 5,配置husky + git钩子 6,配置commitlint 6.1,配置commitlint格 ...
- vue项目和django项目交互补充,drf介绍,restful规范
目录 一.vue项目与django项目的交互 二.drf(Django-restframework) 1. drf主要知识点 2. drf框架安装 3. web接口(WEB API) 4. restf ...
- Vue 项目实战系列 (一)
最近一直在学习Vue,基本的文档看完后就需要进行具体的项目进行练手了,本系列文章主要是将我学习过程记录下来,和大家一起学习交流. 我在git上找到了一个淘票票的Vue项目,项目地址: https:// ...
- 简单vue项目脚手架(vue+webpack2.0+vuex+vue-router)
github地址 使用技术栈 webpack(^2.6.1) webpack-dev-server(^2.4.5) vue(^2.3.3) vuex(^2.3.1) vue-router(^2.5.3 ...
- vue 项目中实用的小技巧
# 在Vue 项目中引入Bootstrap 有时在vue项目中会根据需求引入Bootstrap,而Bootstrap又是依赖于jQuery的,在使用npm按照时,可能会出现一系列的错误 1.安装jQu ...
- 如何在VUE项目中添加ESLint
如何在VUE项目中添加ESLint 1. 首先在项目的根目录下 新建 .eslintrc.js文件,其配置规则可以如下:(自己小整理了一份),所有的代码如下: // https://eslint.or ...
随机推荐
- MyBatis高级篇之整合ehcache缓存框架
MyBatis高级篇之整合ehcache缓存框架 2017-09-01 0 Comments 1,671 Views 0 Times 一.前言 MyBatis为我们提供了Cache接口,也提供 ...
- 转一篇用分布式解决ERP问题
https://www.cnblogs.com/liuche/p/7955462.html
- int LL数据范围
unsigned int 0-4294967295 0~4e9 int -2147483648-2147483647 -2e9~2e9 unsigned long 0-4294967295 long ...
- tarjan算法--求解无向图的割点和桥
1.桥:是存在于无向图中的这样的一条边,如果去掉这一条边,那么整张无向图会分为两部分,这样的一条边称为桥 也就是说 无向连通图中,如果删除某边后,图变成不连通,则称该边为桥 2.割点:无向连通图中,如 ...
- bootstrap 图片切换
<!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title> ...
- 深入探讨 Java 类加载器(转)
原帖地址:https://www.ibm.com/developerworks/cn/java/j-lo-classloader/ 类加载器是 Java 语言的一个创新,也是 Java 语言流行的重要 ...
- net 把指定 URI 的资源下载到本地
DirectoryInfo dir = new DirectoryInfo(AppContext.BaseDirectory); var path = dir.FullName + @"te ...
- 关于css3中的flex
参考几篇文章: Flex 布局语法教程 IE10中的Flexible Box("Flexbox")布局 “老”的Flexbox和“新”的Flexbox 一个可以练习的地方: NEW ...
- python项目飞机大战
实现步骤 1.创建窗口 2.创建一个玩家飞机,按方向键可以左右移动 3.给玩家飞机添加按空格键发射子弹功能 4.创建一个敌机 5.敌机自动左右移动 6.敌机自动发射子弹 1.创建窗口 import p ...
- [转]高端又易学的vbs表白程序了解一下
第一个. 打开txt文件,复制以下代码粘贴进去(可以修改中文部分,其它代码不要动!).保存并关闭txt文件. msgbox("做我女朋友好吗?") msgbox("房产证 ...