前言

代码规范参考借鉴自各个团队规范,提供肉联帮前端团队规范。

基本规范

命名规范

命名分类

  • camelCase(驼峰式,也叫小驼峰命名,e.g. userInfo
  • PascalCase(帕斯卡命名式,也叫大驼峰命名,e.g. UserInfo
  • kebab-case(短横线连接式,e.g. user-info
  • snake_case(下划线连接式,e.g. user_info

    项目命名

    全部采用小写方式, 以下划线分隔。 例:snake_case

    目录命名

    组件目录使用PascalCase,其他目录统一使用kebab-case风格

    HTML命名

    单数复数使用kebab_case.js风格

    CSS命名

    统一使用snake_case.css

    HTML命名

    统一使用snake_case.html

    HTML 规范

    语法标准

  • 缩进使用 tab(2 个空格);

  • 嵌套的节点应该缩进;
  • 在属性上,使用双引号,不要使用单引号;
  • 属性名全小写,用中划线(-)做分隔符;
  • 要在自动闭合标签结尾处使用斜线;

    1. <!DOCTYPE html>
    2. <html>
    3. <head>
    4. <title>Page title</title>
    5. </head>
    6. <body>
    7. <img src="images/image.png" alt="Image" />
    8. <!-- 属性名全小写,用中划线(-)做分隔符 -->
    9. <h1 class="hello-world">Hello, world!</h1>
    10. </body>
    11. </html>

    规定字符编码

    通过声明一个明确的字符编码,让浏览器轻松、快速的确定适合网页内容的渲染方式,通常指定为’UTF-8’。

    1. <!DOCTYPE html>
    2. <html>
    3. <head>
    4. <meta charset="UTF-8" />
    5. </head>
    6. ...
    7. </html>

    减少标签数量

    1. <!-- bad -->
    2. <span class="avatar">
    3. <img src="..." />
    4. </span>
    5. <!-- good -->
    6. <img class="avatar" src="..." />
    7. 复制代码

    语义化标签

    html 的标签能使用语义化的,尽量使用语义化标签,避免一个页面都是 div 或者 p 标签

    1. <!-- bad -->
    2. <div>
    3. <p></p>
    4. </div>
    5. <!-- good -->
    6. <header></header>
    7. <footer></footer>
    8. 复制代码

    CSS规范

    缩进

    使用 tab 缩进(2 个空格)

    1. .element {
    2. border-radius: 10px;
    3. width: 50px;
    4. height: 50px;
    5. }
    6. 复制代码

    分号

    每个声明结束都要加分号

    1. .element {
    2. border-radius: 10px;
    3. width: 50px;
    4. height: 50px;
    5. }
    6. 复制代码

    注释

    注释统一使用 / /

    1. /* 这里是注释 */
    2. .element {
    3. width: 50px;
    4. height: 50px;
    5. }
    6. 复制代码

    引号

  • url 的内容要用引号

  • 属性选择器中的属性值需要引号

    1. .element:after {
    2. content: "";
    3. background-image: url("logo.png");
    4. }
    5. li[data-type="single"] {
    6. ...;
    7. }
    8. 复制代码

    命名

  • 类名使用小写字母,以中划线分隔

  • id 采用驼峰式命名

    1. /* class */
    2. .element-content {
    3. ...;
    4. }
    5. /* id */
    6. #myDialog {
    7. ...;
    8. }
    9. 复制代码

    JavaScript 规范

    缩进

    使用 tab 缩进(2 个空格)

    1. if (x < y) {
    2. x += 10;
    3. } else {
    4. x += 1;
    5. }
    6. 复制代码

    变量命名

  • 变量采用驼峰式命名camelCase

  • 常量使用全大写,用下划线连接
  • 构造函数和Class采用PascalCase ``` var thisIsMyName; var MAX_COUNT = 10; function Person(name) { this.name = name; } Class Person {

} 复制代码

  1. <a name="3d6Tw"></a>
  2. ### 变量声明
  3. 一个函数作用域中所有的变量声明尽量提到函数首部。优先使用块级变量`let` 和 `const`,如无需修改的常量使用`const`
  4. <a name="tZfca"></a>
  5. ### 单行长度
  6. 单行长度不得超过 100,超过部分需要换行
  7. <a name="NLgTr"></a>
  8. ### 分号
  9. 统一要加分号。
  10. <a name="kR6Fo"></a>
  11. ### 空格
  12. - 三元运算符'?:'前后
  13. - 逗号后必须要有空格
  14. - 代码块'{'前
  15. - 下列关键字前:else, while, catch, finally
  16. - 下列关键字后:if, else, for, while, do, switch, case, try,catch, finally, with, return, typeof
  17. - 单行注释'//'后(若单行注释和代码同行,则'//'前也需要),多行注释'*'后
  18. - 对象的属性值前
  19. - for 循环,分号后留有一个空格,前置条件如果有多个,逗号后留一个空格
  20. - 无论是函数声明还是函数表达式,'{'前一定要有空格
  21. - 函数的参数之间
  22. 例:

// not good var a = { b : 1 }; // good var a = { b: 1 }; // not good ++x; y++; z = x ? 1:2; // good ++x; y++; z = x ? 1 : 2; // not good var a = [ 1, 2 ]; // good var a = [1, 2]; // good var doSomething = function(a, b, c) { // do something }; // good doSomething(item); // not good for (let i = 0;i < 6;i++) { x++; } // good for (let i = 0; i < 6; i++) { x++; } 复制代码

  1. <a name="LNXLN"></a>
  2. ### 空行
  3. - 变量声明后(当变量声明在代码块的最后一行时,则无需空行)
  4. - 注释前(当注释在代码块的第一行时,则无需空行)
  5. - 定义函数前
  6. - 文件最后保留一个空行

var x = 1; // 注释前要有空行 if (x >= 1) { var y = x + 1; } function test () { … } 复制代码

  1. <a name="dSWai"></a>
  2. ### 换行
  3. - 代码块'{'后和'}'前<br />
  4. - 变量赋值后<br />

// good var a = { b: 1, c: 2 }; x = y ? 1 : 2; // good if (condition) { … } else { … } try { … } catch (e) { … } finally { … } // good function test() { … } // good var a,foo = 7, b, c, bar = 8; 复制代码

  1. <a name="u5D64"></a>
  2. ### 注释
  3. **单行注释**
  4. - 注释单独一行的情况下,注释的//后面要跟一个空格<br />
  5. - 注释如果和代码同一行,代码分号结束后,要跟一个空格,注释的//后也要跟一个空格<br />

// 调用函数 foo(); var maxCount = 10; // 这是一个变量 复制代码

  1. **多行注释**<br />多行注释使用下面这种形式:

/**

  • 代码注释1
  • 代码注释2 */ 复制代码 ``` 多行注释建议在以下几种情况使用:
  • 难于理解的代码段
  • 可能存在错误的代码段
  • 业务逻辑强相关的代码

  • 函数注释

    复杂的函数,所有类,都必须进行函数注释,函数注释使用业界统一的规范,方便后续使用 jsdoc 生成文档。最好配置VSCode自动生成模板
    例:

    1. /**
    2. * @description 函数描述的 必填
    3. * @param id {Number} 传入需要获取名称的人物id 参数必填
    4. * @return {String} 返回的姓名 返回值必填,空为void
    5. * @author shi 2015/07/21 作者可选
    6. * @version 1.1.0 可以不写 版本可选
    7. * @example 示例代码,可选
    8. */
    9. function getTaskName(id) {
    10. let name = "test";
    11. return name;
    12. }
    13. 复制代码

    引号

    最外层统一使用单引号,除非字符串嵌套的情况使用双引号。

    1. var y = 'foo',
    2. z = '<div id="test"></div>';
    3. 复制代码

    对象,数组

  • 对象属性名不需要加引号,如对象属性名是中划线命名的需要加引号(eslintrules

  • 对象以缩进的形式书写,不要写在一行(单个属性可以写一行,es6 导入方法时可以使用单行);
  • 数组、对象最后不要有逗号。

    1. // good
    2. var a = {
    3. b: 1,
    4. c: 2
    5. };
    6. 复制代码

    括号

    下列关键字后必须有大括号(即使代码块的内容只有一行):if, else, for, while, do, switch, try, catch, finally, with

    1. // not good
    2. if (condition) doSomething();
    3. // good
    4. if (condition) {
    5. doSomething();
    6. }
    7. 复制代码

    undefined

    永远不要直接使用 undefined 进行变量判断;
    使用 typeof 和字符串’undefined’对变量进行判断。

    1. // not good
    2. if (person === undefined) {
    3. ...
    4. }
    5. // good
    6. if (typeof person === 'undefined') {
    7. ...
    8. }
    9. 复制代码

    不允许存在多层嵌套的条件判断和循环(最多三层)(重点强调⭐)

    条件判断能使用三目运算符和逻辑运算符解决的,就不要使用条件判断,但是谨记不要写太长的三目运算符

    1. // bad
    2. if (x === 10) {
    3. return 'valid';
    4. } else {
    5. return 'invalid';
    6. }
    7. // good
    8. return x === 10 ? 'valid' : 'invalid';
    9. // bad
    10. if (!x) {
    11. if (!y) {
    12. x = 1;
    13. } else {
    14. x = y;
    15. }
    16. }
    17. // good
    18. x = x || y || 1;
    19. 复制代码

    Vue规范

    目录、文件、组件命名规范

    1. 目录
    目录统一使用kebab-case风格
    2. views下的文件

  • js类文件使用PascalCase,如UserInfo.js

  • 其他资源文件统一使用kebab-case风格,如user-detail.js, user-detail.css, user-avatar.png

3. 组件文件

  • 命名遵循PascalCase约定。 组件文件名除index.vue之外,一律采用PascalCase(大驼峰)写法。原因是引入组件时,组件的变量通常用PascalCase格式,以区别于一般变量。组件文件名与变量名一致,方便对应。

    1. import UserBook from './user/UserBook'
    2. 复制代码
  • 组件名应该始终是多个单词的,根组件 App 除外 html元素都是单个单词的(如<article>,<header>),为了区分组件和一般html元素,组件由多个单词组成,如BookItem.vue,单独的Book.vue不推荐。

  • 组件使用遵循kebab-case 约定 在页面中使用组件需要前后闭合,并以短线分隔,如:

    1. <user-book></user-book>
    2. <user-book />
    3. 复制代码

    开发规范

    文件结构

  • 基本结构

顺序:template -> script -> style。一个组件尽量不要超过200行,页面包含独立部分时尽量分离成子组件。页面应该由各个小组件组成

  1. <template>
  2. <div>
  3. <component-a />
  4. <component-b />
  5. <component-c />
  6. </div>
  7. </template>
  8. <script>
  9. export default {
  10. components: {},
  11. data() {
  12. return {};
  13. },
  14. created(){},
  15. methods: {},
  16. };
  17. </script>
  18. <!-- 声明语言,并且添加scoped -->
  19. <style lang="scss" scoped>...</style>
  20. 复制代码
  • 组件/实例的选项顺序 ```
  • name (全局引用)
  • components (模板依赖)
  • directives …
  • filters …
  • mixins (组合)
  • props (接口)
  • data (本地状态属性)
  • computed …
  • watch (响应回调)
  • created (生命周期函数)
  • mounted …
  • methods (实例属性) 复制代码 ```

    Vue Router 规范

  • router path采用kebab-case格式。

    用下划线(如:/user_info)或camelCase(如:/userInfo)的单词被当成一个单词,搜索引擎无法区分语义。

  • router name采用kebabCase格式。

    1. // bad
    2. {
    3. path: '/user_info', // user_info当成一个单词
    4. name: 'UserInfo',
    5. component: UserInfo,
    6. meta: {
    7. title: ' - 用户',
    8. desc: ''
    9. }
    10. },
    11. // good
    12. {
    13. path: '/user-info', // 能解析成user info
    14. name: 'UserInfo',
    15. component: UserInfo,
    16. meta: {
    17. title: ' - 用户',
    18. desc: ''
    19. }
    20. 复制代码

    组件开发规范

    1. 注册组件

    注册组件的时候,全部使用 PascalCase 格式。

    1. import UserBook from './user/UserBook'
    2. 复制代码

    2. props 命名规范

  • 在声明prop的时候,其命名应该始终使用camelCase,而在模板中应该始终使用kebab-case

    1. <welcome-message greeting-text="hi"></welcome-message>
    2. <script>
    3. props: {
    4. greetingText: String;
    5. }
    6. </script>
    7. 复制代码
  • prop定义应该尽量详细
    1.申明类型type(必填)
    2.提供默认值(必填
    3.校验类型(可选)

    1. // bad 这样做只有开发原型系统时可以接受
    2. props: ['status']
    3. // good
    4. props: {
    5. status: {
    6. type: String,
    7. required: true,
    8. default: ''
    9. }
    10. }
    11. }
    12. 复制代码

    methods 命名规范

  • 驼峰式命名camelCase,操作性函数统一使用动词或者动词+名词形式 ``` jumpPage() { } openCarInfoDialog () {

} 复制代码

  1. - **请求数据方法,以 data 结尾**

getListData () {

} postFormData () {

} 复制代码

  1. - **注:** 尽量使用常用单词开头(setgetgocanhasis
  2. **附:** 函数方法常用的动词:

get 获取/set 设置, add 增加/remove 删除 create 创建/destory 移除 start 启动/stop 停止 open 打开/close 关闭, read 读取/write 写入 load 载入/save 保存, create 创建/destroy 销毁 begin 开始/end 结束, backup 备份/restore 恢复 import 导入/export 导出, split 分割/merge 合并 inject 注入/extract 提取, attach 附着/detach 脱离 bind 绑定/separate 分离, view 查看/browse 浏览 edit 编辑/modify 修改, select 选取/mark 标记 copy 复制/paste 粘贴, undo 撤销/redo 重做 insert 插入/delete 移除, add 加入/append 添加 clean 清理/clear 清除, index 索引/sort 排序 find 查找/search 搜索, increase 增加/decrease 减少 play 播放/pause 暂停, launch 启动/run 运行 compile 编译/execute 执行, debug 调试/trace 跟踪 observe 观察/listen 监听, build 构建/publish 发布 input 输入/output 输出, encode 编码/decode 解码 encrypt 加密/decrypt 解密, compress 压缩/decompress 解压缩 pack 打包/unpack 解包, parse 解析/emit 生成 connect 连接/disconnect 断开, send 发送/receive 接收 download 下载/upload 上传, refresh 刷新/synchronize 同步 update 更新/revert 复原, lock 锁定/unlock 解锁 check out 签出/check in 签入, submit 提交/commit 交付 push 推/pull 拉, expand 展开/collapse 折叠 begin 起始/end 结束, start 开始/finish 完成 enter 进入/exit 退出, abort 放弃/quit 离开 obsolete 废弃/depreciate 废旧, collect 收集/aggregate 聚集 复制代码

  1. <a name="rWMul"></a>
  2. ### 多个属性的标签元素规范

Vue Logo

Vue Logo

复制代码

  1. <a name="hHWwo"></a>
  2. ### 元素属性的顺序
  3. 原生属性放前面,指令放后面
  • class

    • id,ref
    • name
    • data-*
    • src, for, type, href,value,max-length,max,min,pattern
    • title, alt,placeholder
    • aria-*, role
    • required,readonly,disabled
    • is
    • v-for
    • key
    • v-if
    • v-else-if
    • v-else
    • v-show
    • v-cloak
    • v-pre
    • v-once
    • v-model
    • v-bind,:
    • v-on,@
    • v-html
    • v-text 复制代码 ```

      指令规范

  • 指令有缩写则一律采用缩写形式

    1. // bad
    2. v-bind:code="code"
    3. v-on:click="getUserData"
    4. // good
    5. :code="code"
    6. @click="getUserData"
    7. 复制代码
  • v-for 循环必须加上 key 属性,在整个 for 循环中 key 需要唯一,添加key可提高性能

    1. <!-- bad -->
    2. <ul>
    3. <li v-for="todo in todos">
    4. {{ todo.text }}
    5. </li>
    6. </ul>
    7. <!-- good -->
    8. <ul>
    9. <li v-for="todo in todos" :key="todo.id">
    10. {{ todo.text }}
    11. </li>
    12. </ul>
    13. 复制代码
  • 避免 v-if 和 v-for 同时用在一个元素上(性能问题)

出现这样的需求,有两种解决方案:
1.将数据替换为一个计算属性,让其返回过滤后的列表

  1. <!-- bad -->
  2. <ul>
  3. <li v-for="user in users" v-if="user.isActive" :key="user.id">
  4. {{ user.name }}
  5. </li>
  6. </ul>
  7. <!-- good -->
  8. <ul>
  9. <li v-for="user in activeUsers" :key="user.id">
  10. {{ user.name }}
  11. </li>
  12. </ul>
  13. <script>
  14. computed: {
  15. activeUsers: function () {
  16. return this.users.filter(function (user) {
  17. return user.isActive
  18. })
  19. }
  20. }
  21. </script>
  22. 复制代码

2.将 v-if 移动至容器元素上 (比如 ul, ol)

  1. <!-- bad -->
  2. <ul>
  3. <li v-for="user in users" v-if="shouldShowUsers" :key="user.id">
  4. {{ user.name }}
  5. </li>
  6. </ul>
  7. <!-- good -->
  8. <ul v-if="shouldShowUsers">
  9. <li v-for="user in users" :key="user.id">
  10. {{ user.name }}
  11. </li>
  12. </ul>
  13. 复制代码

SASS规范

语法选用

SASS有两种语法格式,一种是 SCSS (Sassy CSS),另一种是缩进格式(Indented Syntax),有时称之为 Sass。

团队约定

考虑到 SCSS 语法对 CSS 语法友好的兼容性和扩展性,我们在使用 SASS 编写样式的时候,统一使用 SCSS 语法

注释

SASS支持 CSS 标准的多行注释 / /,同时也支持单行注释 //。

  • 多行注释在使用非 Compressed 模式进行编译后的输出文件中会保留下来,单行注释 // 侧会被移除
  • 多行注释和单行注释在 SASS 编译后输出的压缩 CSS 文件都会被移除
  • 当多行注释内容第一个字符是感叹号 “!” 的时候,即 /! /,SASS 无论用哪一种编译方式编译注释都会保留
  • 注释内容可以加入 SASS 变量

团队约定

  • 全部遵循 CSS 注释规范
  • 不使用 /! / 注释方式
  • 注释内不放 SASS 变量

    1. @charset "UTF-8";
    2. /**
    3. * @desc File Info
    4. * @author liqinuo
    5. * @date 2015-10-10
    6. */
    7. /* Module A
    8. ----------------------------------------------------------------*/
    9. .mod_a {}
    10. /* module A logo */
    11. .mod_a_logo {}
    12. /* module A nav */
    13. .mod_a_nav {}
    14. /* Module B
    15. ----------------------------------------------------------------*/
    16. .mod_b {}
    17. /* module B logo */
    18. .mod_b_logo {}
    19. /* module B nav */
    20. .mod_b_nav {}
    21. 复制代码

    嵌套规范

    选择器嵌套

    1. /* CSS */
    2. .jdc {}
    3. body .jdc {}
    4. /* SCSS */
    5. .jdc {
    6. body & {}
    7. }
    8. 复制代码

    属性嵌套

    1. /* CSS */
    2. .jdc {
    3. background-color: red;
    4. background-repeat: no-repeat;
    5. background-image: url(/img/icon.png);
    6. background-position: 0 0;
    7. }
    8. /* SCSS */
    9. .jdc {
    10. background: {
    11. color: red;
    12. repeat: no-repeat;
    13. image: url(/img/icon.png);
    14. position: 0 0;
    15. }
    16. }
    17. 复制代码

    变量

    可复用属性尽量抽离为页面变量,易于统一维护

    1. // CSS
    2. .jdc {
    3. color: red;
    4. border-color: red;
    5. }
    6. // SCSS
    7. $color: red;
    8. .jdc {
    9. color: $color;
    10. border-color: $color;
    11. }
    12. 复制代码

    混合(mixin)

    根据功能定义模块,然后在需要使用的地方通过 @include 调用,避免编码时重复输入代码段

    1. // CSS
    2. .jdc_1 {
    3. -webkit-border-radius: 5px;
    4. border-radius: 5px;
    5. }
    6. .jdc_2 {
    7. -webkit-border-radius: 10px;
    8. border-radius: 10px;
    9. }
    10. // SCSS
    11. @mixin radius($radius:5px) {
    12. -webkit-border-radius: $radius;
    13. border-radius: $radius;
    14. }
    15. .jdc_1 {
    16. @include radius; //参数使用默认值
    17. }
    18. .jdc_2 {
    19. @include radius(10px);
    20. }
    21. // CSS
    22. .jdc_1 {
    23. background: url(/img/icon.png) no-repeat -10px 0;
    24. }
    25. .jdc_2 {
    26. background: url(/img/icon.png) no-repeat -20px 0;
    27. }
    28. // SCSS
    29. @mixin icon($x:0, $y:0) {
    30. background: url(/img/icon.png) no-repeat $x, $y;
    31. }
    32. .jdc_1 {
    33. @include icon(-10px, 0);
    34. }
    35. .jdc_2 {
    36. @include icon(-20px, 0);
    37. }
    38. 复制代码

    占位选择器 %

    如果不调用则不会有任何多余的 css 文件,占位选择器以 % 标识定义,通过 @extend 调用

    1. //scss
    2. %borderbox {
    3. -webkit-box-sizing: border-box;
    4. box-sizing: border-box;
    5. }
    6. .jdc {
    7. @extend %borderbox;
    8. }
    9. 复制代码

    extend 继承

    可以继承复用公共的属性

    1. // CSS
    2. .jdc_1 {
    3. font-size: 12px;
    4. color: red;
    5. }
    6. .jdc_2 {
    7. font-size: 12px;
    8. color: red;
    9. font-weight: bold;
    10. }
    11. // SCSS
    12. .jdc_1 {
    13. font-size: 12px;
    14. color: red;
    15. }
    16. .jdc_2 {
    17. @extend .jdc_1;
    18. font-weight: bold;
    19. }
    20. // 或者
    21. %font_red {
    22. font-size: 12px;
    23. color: red;
    24. }
    25. .jdc_1 {
    26. @extend %font_red;
    27. }
    28. .jdc_2 {
    29. @extend %font_red;
    30. font-weight: bold;
    31. }
    32. 复制代码

    for 循环

    1. // CSS
    2. .jdc_1 {background-position: 0 -20px;}
    3. .jdc_2 {background-position: 0 -40px;}
    4. .jdc_3 {background-position: 0 -60px;}
    5. // SCSS
    6. @for $i from 1 through 3 {
    7. .jdc_#{$i} {
    8. background-position: 0 (-20px) * $i;
    9. }
    10. }
    11. 复制代码

    注意: #{} 是连接符,变量连接使用时需要依赖

    each 循环

    1. // CSS
    2. .jdc_list {
    3. background-image: url(/img/jdc_list.png);
    4. }
    5. .jdc_detail {
    6. background-image: url(/img/jdc_detail.png);
    7. }
    8. // SCSS
    9. @each $name in list, detail {
    10. .jdc_#{$name} {
    11. background-image: url(/img/jdc_#{$name}.png);
    12. }
    13. }
    14. // CSS
    15. .jdc_list {
    16. background-image: url(/img/jdc_list.png);
    17. background-color: red;
    18. }
    19. .jdc_detail {
    20. background-image: url(/img/jdc_detail.png);
    21. background-color: blue;
    22. }
    23. // SCSS
    24. @each $name, $color in (list, red), (detail, blue) {
    25. .jdc_#{$name} {
    26. background-image: url(/img/jdc_#{$name}.png);
    27. background-color: $color;
    28. }
    29. }
    30. 复制代码

    function 函数

    1. @function pxToRem($px) {
    2. @return $px / 10px * 1rem;
    3. }
    4. .jdc {
    5. font-size: pxToRem(12px);
    6. }
    7. 复制代码

    运算规范

    运算符之间空出一个空格

    1. .jdc {
    2. width: 100px - 50px;
    3. height: 30px / 5;
    4. }
    5. 复制代码

    注意: 运算单位,单位同时参与运算,所以 10px 不等于 10,乘除运算时需要特别注意

    1. // 正确的运算格式
    2. .jdc {
    3. width: 100px - 50px;
    4. width: 100px + 50px;
    5. width: 100px * 2;
    6. width: 100px / 2;
    7. }
    8. 复制代码

    小程序规范

    目录、文件、组件命名规范

    1. 目录
    目录统一使用kebab-case风格
    2. page下的文件

  • js类文件使用PascalCase,如UserInfo.js

  • 其他资源文件统一使用kebab-case风格,如user-detail.js, user-detail.css, user-avatar.png

3. 组件文件

  • 命名遵循PascalCase约定。 组件文件名除index.vue之外,一律采用PascalCase(大驼峰)写法。原因是引入组件时,组件的变量通常用PascalCase格式,以区别于一般变量。组件文件名与变量名一致,方便对应。

    1. "usingComponents": {
    2. "select-store-dialog": "../login/components/SelectStoreDialog/index"
    3. }
    4. 复制代码
  • 组件名应该始终是多个单词的,组件由多个单词组成,如BookItem,单独的Book不推荐。

  • 组件使用遵循kebab-case 约定 在页面中使用组件需要前后闭合,并以短线分隔,如:
    1. <user-book></user-book>
    2. <user-book />
    3. 复制代码

    组件的选项顺序

    页面组件 ```
  • data (数据)
  • 生命周期函数 (onLoad等)
  • 各类方法 (methods)
    复制代码
    1. 自定义组件
  • properties (需要传得数据)
  • data (数据)
  • 组件钩子函数 (attached等)
  • 页面钩子函数 (show等)
  • 各类方法 (methods)
    复制代码

    1. <a name="UKmJj"></a>
    2. ### 组件开发规范
    3. <a name="Ng0Oy"></a>
    4. #### 1. 注册组件
    5. 注册组件的时候,全部使用 `PascalCase` 格式。

    “usingComponents”: { “select-store-dialog”: “../login/components/SelectStoreDialog/index” } 复制代码 ```

    2. properties 命名规范

  • 在声明properties的时候,其命名应该始终使用camelCase,而在模板中应该始终使用kebab-case

    1. <!--wxml-->
    2. <welcome-message greeting-text="hi"></welcome-message>
    3. 复制代码
  • properties定义应该尽量详细
    1.申明类型type(必填)
    2.提供默认值(必填)
    ``` /**

  • 组件的属性列表 */ properties: { content:{ type: Object, value: {} } } 复制代码 ```

    methods 命名规范

  • 驼峰式命名camelCase,操作性函数统一使用动词或者动词+名词形式 ``` jumpPage() { } openCarInfoDialog () {

} 复制代码

  1. - **请求数据方法,以 data 结尾**

getListData () {

} postFormData () {

} 复制代码

  1. - **注:** 尽量使用常用单词开头(setgetgocanhasis
  2. **附:** 函数方法常用的动词:

get 获取/set 设置, add 增加/remove 删除 create 创建/destory 移除 start 启动/stop 停止 open 打开/close 关闭, read 读取/write 写入 load 载入/save 保存, create 创建/destroy 销毁 begin 开始/end 结束, backup 备份/restore 恢复 import 导入/export 导出, split 分割/merge 合并 inject 注入/extract 提取, attach 附着/detach 脱离 bind 绑定/separate 分离, view 查看/browse 浏览 edit 编辑/modify 修改, select 选取/mark 标记 copy 复制/paste 粘贴, undo 撤销/redo 重做 insert 插入/delete 移除, add 加入/append 添加 clean 清理/clear 清除, index 索引/sort 排序 find 查找/search 搜索, increase 增加/decrease 减少 play 播放/pause 暂停, launch 启动/run 运行 compile 编译/execute 执行, debug 调试/trace 跟踪 observe 观察/listen 监听, build 构建/publish 发布 input 输入/output 输出, encode 编码/decode 解码 encrypt 加密/decrypt 解密, compress 压缩/decompress 解压缩 pack 打包/unpack 解包, parse 解析/emit 生成 connect 连接/disconnect 断开, send 发送/receive 接收 download 下载/upload 上传, refresh 刷新/synchronize 同步 update 更新/revert 复原, lock 锁定/unlock 解锁 check out 签出/check in 签入, submit 提交/commit 交付 push 推/pull 拉, expand 展开/collapse 折叠 begin 起始/end 结束, start 开始/finish 完成 enter 进入/exit 退出, abort 放弃/quit 离开 obsolete 废弃/depreciate 废旧, collect 收集/aggregate 聚集 复制代码

  1. <a name="Y95yn"></a>
  2. ### 多个属性的标签元素规范

前端代码规范一 - 图3

前端代码规范一 - 图4

复制代码

  1. <a name="g1rks"></a>
  2. ### 元素属性的顺序
  3. 官方属性放前面,自定义属性放后面,然后指令最后