Vue開發風格指南

組件數據

組件的 data 必須是一個函數。

// bad
export default {
  data: {
    foo: 'bar',
  },
};

// good
export default {
  data() {
    return {
      foo: 'bar',
    };
  },
};

單文件組件文件名稱

單文件組件的文件名應該要么始終是單詞大寫開頭 (PascalCase),要么始終是橫線連接 (kebab-case)。

// bad
mycomponent.vue
myComponent.vue

// good
my-component.vue
MyComponent.vue

緊密耦合的組件名

和父組件緊密耦合的子組件應該以父組件名作為前綴命名。

// bad
components/
|- TodoList.vue
|- TodoItem.vue
└─ TodoButton.vue

// good
components/
|- TodoList.vue
|- TodoListItem.vue
└─ TodoListItemButton.vue

自閉合組件

在單文件組件中沒有內容的組件應該是自閉合的。

<!-- bad -->
<my-component></my-component>

<!-- good -->
<my-component />

Prop 名大小寫

在聲明 prop 的時候,其命名應該始終使用 camelCase,而在模板中應該始終使用 kebab-case。

// bad
export default {
  props: {
    'greeting-text': String,
  },
};

// good
export default {
  props: {
    greetingText: String,
  },
};
<!-- bad -->
<welcome-message greetingText="hi" />

<!-- good -->
<welcome-message greeting-text="hi" />

指令縮寫

指令縮寫,用 : 表示 v-bind: ,用 @ 表示 v-on:

<!-- bad -->
<input v-bind:value="value" v-on:input="onInput" />

<!-- good -->
<input :value="value" @input="onInput" />

Props 順序

標簽的 Props 應該有統一的順序,依次為指令、屬性和事件。

<my-component
  v-if="if"
  v-show="show"
  v-model="value"
  ref="ref"
  :key="key"
  :text="text"
  @input="onInput"
  @change="onChange"
/>

組件選項的順序

組件選項應該有統一的順序。

export default {
  name: '',

  mixins: [],

  components: {},

  props: {},

  data() {},

  computed: {},

  watch: {},

  created() {},

  mounted() {},

  destroyed() {},

  methods: {},
};

組件選項中的空行

組件選項較多時,建議在屬性之間添加空行。

export default {
  computed: {
    formattedValue() {
      // ...
    },

    styles() {
      // ...
    },
  },

  methods: {
    onInput() {
      // ...
    },

    onChange() {
      // ...
    },
  },
};

單文件組件頂級標簽的順序

單文件組件應該總是讓頂級標簽的順序保持一致,且標簽之間留有空行。

<template>
  ...
</template>

<script>
  /* ... */
</script>

<style>
  /* ... */
</style>
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • title: 風格指南type: style-guide 這里是官方的 Vue 特有代碼的風格指南。如果在工程中使...
    ChenyuMa閱讀 1,088評論 1 1
  • 命名規范 A優先級 組件名應該始終是多個單詞:避免跟現有的以及未來的 HTML 元素相沖突 B優先級 單文件組件的...
    小焲閱讀 475評論 0 0
  • Vue 官方在最近發布了代碼風格指南的BETA版本,旨在引導開發者以正確的方式來書寫代碼,避免因為不規范而導致的問...
    白色鵜鶘鳥閱讀 1,023評論 0 4
  • 組件數據 組件的 data 必須是一個函數。 單文件組件文件名稱 單文件組件的文件名應該要么始終是單詞大寫開頭 (...
    晨晨_103e閱讀 154評論 0 0
  • 這里是官方的 Vue 特有代碼的風格指南。如果在工程中使用 Vue,為了回避錯誤、小糾結和反模式,該指南是份不錯的...
    youins閱讀 5,748評論 0 5