列表

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 项目其他规范的更多相关文章

  1. 团队开发前端VUE项目代码规范

    团队开发前端VUE项目代码规范 2018年09月22日 20:18:11 我的小英短 阅读数 1658   一.规范目的: 统一编码风格,命名规范,注释要求,在团队协作中输出可读性强,易维护,风格一致 ...

  2. 【转载】Vue项目中的文件/文件夹命名规范

    文件或文件夹的命名遵循以下原则: index.js 或者 index.vue,统一使用小写字母开头的(kebab-case)命名规范 属于组件或类的,统一使用大写字母开头的(PascalCase)命名 ...

  3. Vue项目中的文件/文件夹命名规范

    Vue项目中的文件/文件夹命名规范 0.2262018.09.21 16:01:09字数 820阅读 6979 文件或文件夹的命名遵循以下原则: index.js 或者 index.vue,统一使用小 ...

  4. 手把手教你搭建规范的团队vue项目,包含commitlint,eslint,prettier,husky,commitizen等等

    目录 1,前言 2,创建项目 2,安装vue全家桶 3,配置prettier 4,配置eslint 5,配置husky + git钩子 6,配置commitlint 6.1,配置commitlint格 ...

  5. vue项目和django项目交互补充,drf介绍,restful规范

    目录 一.vue项目与django项目的交互 二.drf(Django-restframework) 1. drf主要知识点 2. drf框架安装 3. web接口(WEB API) 4. restf ...

  6. Vue 项目实战系列 (一)

    最近一直在学习Vue,基本的文档看完后就需要进行具体的项目进行练手了,本系列文章主要是将我学习过程记录下来,和大家一起学习交流. 我在git上找到了一个淘票票的Vue项目,项目地址: https:// ...

  7. 简单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 ...

  8. vue 项目中实用的小技巧

    # 在Vue 项目中引入Bootstrap 有时在vue项目中会根据需求引入Bootstrap,而Bootstrap又是依赖于jQuery的,在使用npm按照时,可能会出现一系列的错误 1.安装jQu ...

  9. 如何在VUE项目中添加ESLint

    如何在VUE项目中添加ESLint 1. 首先在项目的根目录下 新建 .eslintrc.js文件,其配置规则可以如下:(自己小整理了一份),所有的代码如下: // https://eslint.or ...

随机推荐

  1. 最长上升子序列 and 最长公共子序列 问题模板

    两种求最长上升子序列问题 第一种:定义dp[i]=以a[i]为末尾的最长上升子序列问题的长度 第二种:定义dp[i]=长度为i+1的上升 子序列 中末尾元素的最小值 #include <cstd ...

  2. Allegro中常见的文件格式

    allegro/APD.jrl : 记录开启 Allegro/APD 期间每一个执行动作的 command .产生在每一次新开启 Allegro/APD 的现行工作目录下 .env : 存在 pcbe ...

  3. jmeter 中 浮点数计算精度问题

    jmeter 中 浮点数计算精度问题解决方法: 编写 beanshell 时使用 java.math.BigDecimal 方法构造,使用 BigDecimal 并且一定要用 String 来够造. ...

  4. underscore.js源码研究(4)

    概述 很早就想研究underscore源码了,虽然underscore.js这个库有些过时了,但是我还是想学习一下库的架构,函数式编程以及常用方法的编写这些方面的内容,又恰好没什么其它要研究的了,所以 ...

  5. Vue+WebSocket+ES6+Canvas 制作「你画我猜」小游戏

    Vue+WebSocket+ES6+Canvas 制作「你画我猜」小游戏 转载 来源:jrainlau 链接:https://segmentfault.com/a/1190000005804860 项 ...

  6. Smart/400开发上手3: 练习实践

    练习题 在2006年1月1日之前入职且在职的营销员,给予年资补贴2000元: 符合以上条件的,再按以下标准一次性发放职级补贴: 职级代码 简称 补偿金额 A1 AD 6000 B1 SBM 5000 ...

  7. golang 切片和数组在for...range中的区别

    切片是引用类型,而数组是值类型,并且for...range有以下规则: range表达式只会在for语句开始执行时被求值一次,无论后边会有多少次迭代 range表达式的求值结果会被复制,也就是说,被迭 ...

  8. tkinter的grid布局中合并单元格

    rowspan  合并多行,比如:Label(root,text="table",width=10,height=2,),grid(row=0,column=0,rowspan=2 ...

  9. android设备不识别awk命令,缺少busybox

    android设备不识别awk命令,缺少busybox 一.什么是BusyBox ? BusyBox 是标准 Linux 工具的一个单个可执行实现.BusyBox 包含了一些简单的工具,例如 cat ...

  10. C# 获取所有对象的字符串表示一ToString方法

    应用程序开发过程中经常需要获取对象的字符串表示.Object类中定义了一个ToString的虚方法.所以在任何类型的实例上都能调用该方法. C#中几乎所有的类型都派生自Object,所以如果当前类型没 ...