Vue.js 支持通過?`ref`?屬性來訪問其它組件和 HTML 元素。并通過?`this.$refs`?可以得到組件或 HTML 元素的上下文。在大多數情況下,通過?`this.$refs`來訪問其它組件的上下文是可以避免的。在使用的的時候你需要注意避免調用了不恰當的組件 API,所以應該盡量避免使用?`this.$refs`。
### [](https://github.com/pablohpsilva/vuejs-component-style-guide/blob/master/README-CN.md#為什么-8)為什么?
* 組件必須是保持獨立的,如果一個組件的 API 不能夠提供所需的功能,那么這個組件在設計、實現上是有問題的。
* 組件的屬性和事件必須足夠的給大多數的組件使用。
### [](https://github.com/pablohpsilva/vuejs-component-style-guide/blob/master/README-CN.md#怎么做-8)怎么做?
* 提供良好的組件 API。
* 總是關注于組件本身的目的。
* 拒絕定制代碼。如果你在一個通用的組件內部編寫特定需求的代碼,那么代表這個組件的 API 不夠通用,或者你可能需要一個新的組件來應對該需求。
* 檢查所有的 props 是否有缺失的,如果有提一個 issue 或是完善這個組件。
* 檢查所有的事件。子組件向父組件通信一般是通過事件來實現的,但是大多數的開發者更多的關注于 props 從忽視了這點。
* Props向下傳遞,事件向上傳遞!。以此為目標升級你的組件,提供良好的 API 和 獨立性。
* 當遇到 props 和 events 難以實現的功能時,通過?`this.$refs`來實現。
* 當需要操作 DOM 無法通過指令來做的時候可使用?`this.$ref`?而不是?`JQuery`、`document.getElement*`、`document.queryElement`。
~~~
<!-- 推薦,并未使用 this.$refs -->
<range :max="max"
:min="min"
:step="1"
@current-value="currentValue"
></range>
~~~
~~~
<!-- 使用 this.$refs 的適用情況-->
<modal ref="basicModal">
<h4>Basic Modal</h4>
<button class="primary" @click="$refs.basicModal.hide()">Close</button>
</modal>
<button @click="$refs.basicModal.open()">Open modal</button>
<!-- Modal component -->
<template>
<div v-show="active">
<!-- ... -->
</div>
</template>
<script>
export default {
// ...
data() {
return {
active: false,
};
},
methods: {
open() {
this.active = true;
},
hide() {
this.active = false;
},
},
// ...
};
</script>
~~~
~~~
<!-- 如果可通過 emited 來做則避免通過 this.$refs 直接訪問 -->
<template>
<range :max="max"
:min="min"
:step="1"
ref="range"
></range>
</template>
<script>
export default {
// ...
methods: {
getRangeCurrentValue() {
return this.$refs.range.currentValue
},
},
// ...
};
</script>
~~~
- Vue開發規范
- 基于模塊開發
- 組件
- 組件命名規則
- 基礎組件名
- 單例組件名
- 緊密耦合的組件名
- 組件名中的單詞順序
- 組件文件夾命名規則
- method方法
- methods方法命名規則
- 組件結構化
- 組件事件命名規則
- v-for與v-if
- 為 v-for 設置鍵值
- 避免 v-if 和 v-for 用在一起
- Prop
- Prop命名規則
- Prop定義
- 避免 this.$parent
- 謹慎使用 this.$refs
- 隱性的父子組件通信
- 元素
- 元素特性的順序
- 多個特性的元素擺放規則
- 單文件組件的頂級元素的順序
- 簡化代碼
- 模板中簡單的表達式
- 簡單的計算屬性
- 指令縮寫
- 文件引用路徑
- 其他注意
- 組件數據
- 將 this 賦值給 component 變量
- 對組件文件進行代碼校驗
- 盡可能使用 mixins
- 非 Flux 的全局狀態管理
- 只在需要時創建組件
- HTML開發規范
- HTML語法
- HTML5 doctype
- 語言屬性
- IE 兼容模式
- 字符編碼
- 引入 CSS 和 JavaScript 文件
- 實用為王
- 屬性順序
- 布爾(boolean)型屬性
- 減少標簽的數量
- JavaScript 生成的標簽
- CSS開發規范
- CSS語法
- 聲明順序
- 不要使用 @import
- 媒體查詢(Media query)的位置
- 帶前綴的屬性
- 單行規則聲明
- 簡寫形式的屬性聲明
- Less 和 Sass 中的嵌套
- Less 和 Sass 中的操作符
- 注釋
- class 命名
- 選擇器
- 代碼組織