Vue风格指南总结

命名规范

A优先级

  1. 组件名应该始终是多个单词:避免跟现有的以及未来的 HTML 元素相冲突

B优先级

  1. 单文件组件的文件名应该要么始终是单词大写开头 (PascalCase),要么始终是横线连接 (kebab-case);
  2. 应用特定样式和约定的基础组件 (也就是展示类的、无逻辑的或无状态的组件) 应该全部以一个特定的前缀开头,比如 Base、App 或 V。
  3. 只应该拥有单个活跃实例的组件应该以 The 前缀命名,以示其唯一性。
  4. 父组件紧密耦合的子组件应该以父组件名作为前缀命名。
  5. 单词顺序:组件名应该以高级别的 (通常是一般化描述的) 单词开头,以描述性的修饰词结尾。
  6. 对于绝大多数项目来说,在单文件组件和字符串模板中组件名应该总是 PascalCase 的——但是在 **DOM **模板中总是 kebab-case 的。
  7. JS/JSX 中的组件名应该始终是 PascalCase 的,尽管在较为简单的应用中只使用 Vue.component 进行全局组件注册时,可以使用 kebab-case 字符串。
  8. 组件名应该倾向于完整单词而不是缩写。
  9. 在声明 prop 的时候,其命名应该始终使用 camelCase,而在模板和 JSX中应该始终使用 kebab-case。

其他

A优先级

  1. 组件的 data 必须是一个函数。
  2. prop 的定义应该尽量详细,至少需要指定其类型。
  3. 总是用 key 配合 v-for。
  4. 永远不要把 v-if 和 v-for 同时用在同一个元素上。
  5. 所有组件都应该是有作用域的。针对style,可以使用scoped 特性、CSS Modules和BEM 约定。
  6. 在插件、混入等扩展中始终为自定义的私有属性使用 $_ 前缀。并附带一个命名空间以回避和其它作者的冲突 (比如 $_yourPluginName_)。

B优先级

  1. 只要有能够拼接文件的构建系统,就把每个组件单独分成文件。
  2. 单文件组件、字符串模板和 JSX 中没有内容的组件应该是自闭合的——但在 DOM 模板里永远不要这样做。
  3. 多个特性的元素应该分多行撰写,每个特性一行。
  4. 组件模板应该只包含简单的表达式,复杂的表达式则应该重构为计算属性或方法。
  5. 应该把复杂计算属性分割为尽可能多的更简单的属性。
  6. 非空 HTML 特性值应该始终带引号 (单引号或双引号,选你 JS 里不用的那个)。
  7. 指令缩写 (用 : 表示 v-bind: 和用 @ 表示 v-on:) 应该要么都用要么都不用。

C优先级

  1. 组件/实例的选项应该有统一的顺序。
  1. 副作用 (触发组件外的影响)
    el
  2. 全局感知 (要求组件以外的知识)
    name
    parent
  3. 组件类型 (更改组件的类型)
    functional
  4. 模板修改器 (改变模板的编译方式)
    delimiters
    comments
  5. 模板依赖 (模板内使用的资源)
    components
    directives
    filters
  6. 组合 (向选项里合并属性)
    extends
    mixins
  7. 接口 (组件的接口)
    inheritAttrs
    model
    props/propsData
  8. 本地状态 (本地的响应式属性)
    data
    computed
  9. 事件 (通过响应式事件触发的回调)
    watch
    生命周期钩子 (按照它们被调用的顺序)
  10. 非响应式的属性 (不依赖响应系统的实例属性)
    methods
  11. 渲染 (组件输出的声明式描述)
    template/render
    renderError
  1. 元素 (包括组件) 的特性应该有统一的顺序。
  1. 定义 (提供组件的选项)
    is
  2. 列表渲染 (创建多个变化的相同元素)
    v-for
  3. 条件渲染 (元素是否渲染/显示)
    v-if
    v-else-if
    v-else
    v-show
    v-cloak
  4. 渲染方式 (改变元素的渲染方式)
    v-pre
    v-once
  5. 全局感知 (需要超越组件的知识)
    id
  6. 唯一的特性 (需要唯一值的特性)
    ref
    key
    slot
  7. 双向绑定 (把绑定和事件结合起来)
    v-model
  8. 其它特性 (所有普通的绑定或未绑定的特性)
  9. 事件 (组件事件监听器)
    v-on
  10. 内容 (覆写元素的内容)
    v-html
    v-text
  1. 当你的组件开始觉得密集或难以阅读时,在多个属性之间添加空行可以让其变得容易。
props: {
  value: {
    type: String,
    required: true
  },

  focused: {
    type: Boolean,
    default: false
  },

  label: String,
  icon: String
},

computed: {
  formattedValue: function () {
    // ...
  },

  inputClasses: function () {
    // ...
  }
}
  1. 单文件组件应该总是让 <script><template><style> 标签的顺序保持一致。且 <style> 要放在最后,因为另外两个标签至少要有一个。
<script>/* ... */</script>
<template>...</template>
<style>/* ... */</style>
<!-- 或者 -->
<template>...</template>
<script>/* ... */</script>
<style>/* ... */</style>

参考文献:Vue风格指南

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • title: 风格指南type: style-guide 这里是官方的 Vue 特有代码的风格指南。如果在工程中使...
    ChenyuMa阅读 1,053评论 1 1
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,044评论 0 29
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 10,982评论 4 129
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,198评论 0 6
  • 儿子今天参加钢琴的八级考试。早晨刚要出门跑步,但我还是停下了脚步。考试是要提前至少半个小时的。孩子还要有一个平静的...
    阳光滕君阅读 162评论 0 0