1. 程式人生 > 程式設計 >Vue常用API、高階API的相關總結

Vue常用API、高階API的相關總結

最近手癢癢,玩兒了一下Vue3.0,很舒服,趕緊把這幾期Vue2.0弄完,寫一些3.0的東西。
本文主要羅列和解析一些個人認為常用或有大用途的Api,作為自我總結的筆記和探討。

nextTick

功能:

新增在下次Dom更新迴圈結束之後的延遲迴調,修改資料之後,可以獲取更新後的Dom。
用法:

Vue.nextTick( [callback,context] )
vm.$nextTick( [callback] )
// 用法2
// 作為一個 Promise 使用 (2.1.0 起新增)
Vue.nextTick()
 .then(function () {
  // DOM 更新了
 })

說明:

callback:延遲迴調函式

context:可選的object
ps:2.1.0 起新增:如果沒有提供回撥且在支援 Promise 的環境中,則返回一個 Promise。請注意 Vue 不自帶 Promise 的 polyfill,所以如果你的目標瀏覽器不原生支援 Promise (IE:你們都看我幹嘛),你得自己提供 polyfill。

擴充套件:

關於nextTick的執行機制和使用場景,我們還必須掌握類似的requestAnimationFrame() 和 process.nextTick(), 前者是瀏覽器自帶的監聽(在下次重繪之前執行),後者是node環境下,在下一個事件輪詢的時間點上執行

mixin

功能:

註冊一個混入,影響註冊之後所有建立的每個 Vue 例項。外掛作者可以使用混入,向元件注入自定義的行為。
用法:

// 為自定義的選項 'myOption' 注入一個處理器。
Vue.mixin({
 created: function () {
  var myOption = this.$options.myOption
  if (myOption) {
   console.log(myOption)
  }
 }
})

new Vue({
 myOption: 'hello!'
})
// => "hello!"

說明:

object:一個vm的屬性或方法
ps:請謹慎使用全域性混入,因為它會影響每個單獨建立的 Vue 例項 (包括第三方元件)。大多數情況下,只應當應用於自定義選項,就像上面示例一樣。推薦將其作為外掛釋出,以避免重複應用混入。

$forceUpdate

功能:

迫使 Vue 例項重新渲染。
用法:

vm.$forceUpdate()

set、delete

功能:

對響應式資料的屬性進行設定、刪除,同時觸發檢視更新。
用法:

// 用法1
Vue.set( target,key,value )
Vue.delete( target,key )
// 用法2
vm.$set( target,value )
vm.$delete( target,key )

說明:

target:目標物件
key:要新增的屬性名
value:要新增的屬性值
ps:主要使用場景,可以避開 Vue 不能檢測到 property 被刪除的限制

filter

功能:

用於一些常見的文字格式化和一些規範資料mapping。
用法:

<!-- 在雙花括號中 -->
{{ message | capitalize }}

<!-- 在 `v-bind` 中 -->
<div v-bind:id="rawId | formatId"></div>
// 註冊
filters: {
 capitalize: function (value) {
  if (!value) return ''
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
 }
}
// 全域性註冊
Vue.filter('capitalize',function (value) {
 if (!value) return ''
 value = value.toString()
 return value.charAt(0).toUpperCase() + value.slice(1)
})

new Vue({
 // ...
})

說明:

過濾器函式總接收表示式的值 (之前的操作鏈的結果) 作為第一個引數。
過濾器應該被新增在 JavaScript 表示式的尾部,由“管道”符號指示。

ps:過濾器可以接受多個引數,如{{ message | filterA('arg1',arg2) }},這裡,filterA 被定義為接收三個引數的過濾器函式。其中 message 的值作為第一個引數,普通字串 'arg1' 作為第二個引數,表示式 arg2 的值作為第三個引數。

directive

功能:

用於註冊自定義指令。

用法:

<!-- 當頁面載入時,該元素將獲得焦點 --> 
<input v-focus>
// 註冊一個全域性自定義指令 `v-focus`
Vue.directive('focus',{
 // 當被繫結的元素插入到 DOM 中時……
 inserted: function (el) {
  // 聚焦元素
  el.focus()
 }
})
// 註冊區域性指令,元件中也接受一個 directives 的選項
directives: {
 focus: {
  // 指令的定義
  inserted: function (el) {
   el.focus()
  }
 }
}

說明:

inserted 只是註冊指令的其中一個插值函式,完整的註冊屬性還可以包括:
bind:只調用一次,指令第一次繫結到元素時呼叫,在這裡可以進行一次性的初始化設定。
inserted:被繫結元素插入父節點時呼叫(僅保證父節點存在,但不一定已被插入文件中)。
update:所在元件的 VNode 更新時呼叫,但是可能發生在其子 VNode 更新之前。指令的值可能發生了改變,也可能沒有,但是可以通過比較更新前後的值來忽略不必要的模板更新。
componentUpdated:指令所在元件的 VNode 及其子 VNode 全部更新後呼叫。
unbind:只調用一次,指令與元素解綁時呼叫。

Vue.directive('my-directive',{
 bind: function () {},inserted: function () {},update: function () {},componentUpdated: function () {},unbind: function () {}
})

其它簡單的常用屬性和方法

// console.log(vm.$root); 
vm.$root  //例項物件

vm.$el //根元素(真實的DOM元素)
// console.log(vm.$el);

vm.$el.innerHTML  //得到根元素(真實的DOM元素)中的內容
// console.log(vm.$el.innerHTML);

vm.$data  //例項下的data物件
// console.log(vm.$data);

vm.$options   //例項下的掛載項
// console.log(vm.$options);

vm.$props  //元件之間通訊的資料
// console.log(vm.$props);

vm.$parent   //在元件中,指父元素
// console.log(vm.$parent);

vm.$children  //在元件中,指子代元素
// console.log(vm.$children);

vm.$attrs  //用來獲取父元件傳遞過來的所有屬性
// console.log(vm.$attrs);

vm.$listeners  //用來獲取父元件傳遞過來的所有方法
// console.log(vm.$listeners);

vm.$slots  //元件中的插槽
// console.log(vm.$slots);

vm.$scopedSlots   //用來訪問作用域插槽
// console.log(vm.$scopedSlots);

vm.$refs  //用來定位DOM元素(使用ref進行追蹤)
// console.log(vm.$refs);

vm.$watch  //用於監聽資料(在vue檔案中使用後會自動銷燬)
// console.log(vm.$watch);

vm.$emit  //用於派發事件(常用於資料通訊)
// console.log(vm.$emit);

vm.$on //用於監聽事件的派發
// console.log(vm.$on);

vm.$once  //只監聽事件一次(之後不監聽)
// console.log(vm.$once);

//生命週期
beforeCreate() {
}
created() {
}
beforeMount() {
}
mounted() {
}
beforeUpdate() {
}
updated() {
}
beforeDestroy() {
}
destroyed() {
}

總結

本文主要收錄vue中常用的這幾個API,如果有興趣學習更多,可以參考其官網。希望本文對你有用,並能熟練運用到實際的專案開發中。

為了方便閱讀理解,本文程式碼已經上傳Github

文中如有錯誤,歡迎在評論區指正,如果有所幫助,歡迎點贊和關注。

以上就是Vue常用API、高階API的相關總結的詳細內容,更多關於Vue常用API、高階API的資料請關注我們其它相關文章!