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, key, 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的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- 關於Vue 自定義指令實現元素拖動的詳細代碼
- vue2.x與vue3.x中自定義指令詳解(最新推薦)
- 分析Vue指令實現原理
- Vue指令工作原理實現方法
- element input輸入框自動獲取焦點的實現