Vue中有哪些常用的API?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

nextTick
功能:
添加在下次Dom更新循環(huán)結(jié)束之后的延遲回調(diào),修改數(shù)據(jù)之后,可以獲取更新后的Dom。
用法:
Vue.nextTick( [callback, context] )
vm.$nextTick( [callback] )
// 用法2
// 作為一個 Promise 使用 (2.1.0 起新增)
Vue.nextTick()
.then(function () {
// DOM 更新了
})說明:
callback:延遲回調(diào)函數(shù)
context:可選的object
ps:2.1.0 起新增:如果沒有提供回調(diào)且在支持 Promise 的環(huán)境中,則返回一個 Promise。請注意 Vue 不自帶 Promise 的 polyfill,所以如果你的目標瀏覽器不原生支持 Promise (IE:你們都看我干嘛),你得自己提供 polyfill。
擴展:
關于nextTick的執(zhí)行機制和使用場景,我們還必須掌握類似的requestAnimationFrame() 和 process.nextTick(), 前者是瀏覽器自帶的監(jiān)聽(在下次重繪之前執(zhí)行),后者是node環(huán)境下,在下一個事件輪詢的時間點上執(zhí)行
功能:
注冊一個混入,影響注冊之后所有創(chuàng)建的每個 Vue 實例。插件作者可以使用混入,向組件注入自定義的行為。
用法:
// 為自定義的選項 'myOption' 注入一個處理器。
Vue.mixin({
created: function () {
var myOption = this.$options.myOption
if (myOption) {
console.log(myOption)
}
}
})
new Vue({
myOption: 'hello!'
})
// => "hello!"說明:
object:一個vm的屬性或方法
ps:請謹慎使用全局混入,因為它會影響每個單獨創(chuàng)建的 Vue 實例 (包括第三方組件)。大多數(shù)情況下,只應當應用于自定義選項,就像上面示例一樣。推薦將其作為插件發(fā)布,以避免重復應用混入。
功能:
迫使 Vue 實例重新渲染。
用法:
vm.$forceUpdate()
功能:
對響應式數(shù)據(jù)的屬性進行設置、刪除,同時觸發(fā)視圖更新。
用法:
// 用法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 被刪除的限制
功能:
用于一些常見的文本格式化和一些規(guī)范數(shù)據(jù)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({
// ...
})說明:
過濾器函數(shù)總接收表達式的值 (之前的操作鏈的結(jié)果) 作為第一個參數(shù)。
過濾器應該被添加在 JavaScript 表達式的尾部,由“管道”符號指示。
ps:過濾器可以接受多個參數(shù),如{{ message | filterA('arg1', arg2) }},這里,filterA 被定義為接收三個參數(shù)的過濾器函數(shù)。其中 message 的值作為第一個參數(shù),普通字符串 'arg1' 作為第二個參數(shù),表達式 arg2 的值作為第三個參數(shù)。
功能:
用于注冊自定義指令。
用法:
<!-- 當頁面加載時,該元素將獲得焦點 --> <input v-focus>
// 注冊一個全局自定義指令 `v-focus`
Vue.directive('focus', {
// 當被綁定的元素插入到 DOM 中時……
inserted: function (el) {
// 聚焦元素
el.focus()
}
})// 注冊局部指令,組件中也接受一個 directives 的選項
directives: {
focus: {
// 指令的定義
inserted: function (el) {
el.focus()
}
}
}說明:
inserted 只是注冊指令的其中一個插值函數(shù),完整的注冊屬性還可以包括:
bind:只調(diào)用一次,指令第一次綁定到元素時調(diào)用,在這里可以進行一次性的初始化設置。
inserted:被綁定元素插入父節(jié)點時調(diào)用(僅保證父節(jié)點存在,但不一定已被插入文檔中)。
update:所在組件的 VNode 更新時調(diào)用,但是可能發(fā)生在其子 VNode 更新之前。指令的值可能發(fā)生了改變,也可能沒有,但是可以通過比較更新前后的值來忽略不必要的模板更新。
componentUpdated:指令所在組件的 VNode 及其子 VNode 全部更新后調(diào)用。
unbind:只調(diào)用一次,指令與元素解綁時調(diào)用。
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元素)中的內(nèi)容
// console.log(vm.$el.innerHTML);
vm.$data //實例下的data對象
// console.log(vm.$data);
vm.$options //實例下的掛載項
// console.log(vm.$options);
vm.$props //組件之間通信的數(shù)據(jù)
// 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 //用于監(jiān)聽數(shù)據(jù)(在vue文件中使用后會自動銷毀)
// console.log(vm.$watch);
vm.$emit //用于派發(fā)事件(常用于數(shù)據(jù)通信)
// console.log(vm.$emit);
vm.$on //用于監(jiān)聽事件的派發(fā)
// console.log(vm.$on);
vm.$once //只監(jiān)聽事件一次(之后不監(jiān)聽)
// console.log(vm.$once);
//生命周期
beforeCreate() {
}
created() {
}
beforeMount() {
}
mounted() {
}
beforeUpdate() {
}
updated() {
}
beforeDestroy() {
}
destroyed() {
}看完上述內(nèi)容,你們掌握Vue中有哪些常用的API的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
名稱欄目:Vue中有哪些常用的API-創(chuàng)新互聯(lián)
瀏覽路徑:http://chinadenli.net/article34/cogjpe.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供用戶體驗、網(wǎng)站營銷、App開發(fā)、網(wǎng)站導航、Google、營銷型網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容