亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

Vue常用API、高級API的相關(guān)總結(jié)

瀏覽:2日期:2022-10-06 18:00:17

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

nextTick

功能:

添加在下次Dom更新循環(huán)結(jié)束之后的延遲回調(diào),修改數(shù)據(jù)之后,可以獲取更新后的Dom。用法:

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

說明:

callback:延遲回調(diào)函數(shù)context:可選的objectps:2.1.0 起新增:如果沒有提供回調(diào)且在支持 Promise 的環(huán)境中,則返回一個(gè) Promise。請注意 Vue 不自帶 Promise 的 polyfill,所以如果你的目標(biāo)瀏覽器不原生支持 Promise (IE:你們都看我干嘛),你得自己提供 polyfill。

擴(kuò)展:

關(guān)于nextTick的執(zhí)行機(jī)制和使用場景,我們還必須掌握類似的requestAnimationFrame() 和 process.nextTick(), 前者是瀏覽器自帶的監(jiān)聽(在下次重繪之前執(zhí)行),后者是node環(huán)境下,在下一個(gè)事件輪詢的時(shí)間點(diǎn)上執(zhí)行

mixin

功能:

注冊一個(gè)混入,影響注冊之后所有創(chuàng)建的每個(gè) Vue 實(shí)例。插件作者可以使用混入,向組件注入自定義的行為。用法:

// 為自定義的選項(xiàng) ’myOption’ 注入一個(gè)處理器。Vue.mixin({ created: function () { var myOption = this.$options.myOption if (myOption) { console.log(myOption) } }})new Vue({ myOption: ’hello!’})// => 'hello!'

說明:

object:一個(gè)vm的屬性或方法ps:請謹(jǐn)慎使用全局混入,因?yàn)樗鼤?huì)影響每個(gè)單獨(dú)創(chuàng)建的 Vue 實(shí)例 (包括第三方組件)。大多數(shù)情況下,只應(yīng)當(dāng)應(yīng)用于自定義選項(xiàng),就像上面示例一樣。推薦將其作為插件發(fā)布,以避免重復(fù)應(yīng)用混入。

$forceUpdate

功能:

迫使 Vue 實(shí)例重新渲染。用法:

vm.$forceUpdate()set、delete

功能:

對響應(yīng)式數(shù)據(jù)的屬性進(jìn)行設(shè)置、刪除,同時(shí)觸發(fā)視圖更新。用法:

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

說明:

target:目標(biāo)對象key:要添加的屬性名value:要添加的屬性值ps:主要使用場景,可以避開 Vue 不能檢測到 property 被刪除的限制

filter

功能:

用于一些常見的文本格式化和一些規(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ù)總接收表達(dá)式的值 (之前的操作鏈的結(jié)果) 作為第一個(gè)參數(shù)。過濾器應(yīng)該被添加在 JavaScript 表達(dá)式的尾部,由“管道”符號指示。

ps:過濾器可以接受多個(gè)參數(shù),如{{ message | filterA(’arg1’, arg2) }},這里,filterA 被定義為接收三個(gè)參數(shù)的過濾器函數(shù)。其中 message 的值作為第一個(gè)參數(shù),普通字符串 ’arg1’ 作為第二個(gè)參數(shù),表達(dá)式 arg2 的值作為第三個(gè)參數(shù)。

directive

功能:

用于注冊自定義指令。

用法:

<!-- 當(dāng)頁面加載時(shí),該元素將獲得焦點(diǎn) --> <input v-focus>

// 注冊一個(gè)全局自定義指令 `v-focus`Vue.directive(’focus’, { // 當(dāng)被綁定的元素插入到 DOM 中時(shí)…… inserted: function (el) { // 聚焦元素 el.focus() }})

// 注冊局部指令,組件中也接受一個(gè) directives 的選項(xiàng)directives: { focus: { // 指令的定義 inserted: function (el) { el.focus() } }}

說明:

inserted 只是注冊指令的其中一個(gè)插值函數(shù),完整的注冊屬性還可以包括:bind:只調(diào)用一次,指令第一次綁定到元素時(shí)調(diào)用,在這里可以進(jìn)行一次性的初始化設(shè)置。inserted:被綁定元素插入父節(jié)點(diǎn)時(shí)調(diào)用(僅保證父節(jié)點(diǎn)存在,但不一定已被插入文檔中)。update:所在組件的 VNode 更新時(shí)調(diào)用,但是可能發(fā)生在其子 VNode 更新之前。指令的值可能發(fā)生了改變,也可能沒有,但是可以通過比較更新前后的值來忽略不必要的模板更新。componentUpdated:指令所在組件的 VNode 及其子 VNode 全部更新后調(diào)用。unbind:只調(diào)用一次,指令與元素解綁時(shí)調(diào)用。

Vue.directive(’my-directive’, { bind: function () {}, inserted: function () {}, update: function () {}, componentUpdated: function () {}, unbind: function () {}})其它簡單的常用屬性和方法

// console.log(vm.$root); vm.$root //實(shí)例對象vm.$el //根元素(真實(shí)的DOM元素)// console.log(vm.$el);vm.$el.innerHTML //得到根元素(真實(shí)的DOM元素)中的內(nèi)容// console.log(vm.$el.innerHTML);vm.$data //實(shí)例下的data對象// console.log(vm.$data);vm.$options //實(shí)例下的掛載項(xiàng)// 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進(jìn)行追蹤)// console.log(vm.$refs);vm.$watch //用于監(jiān)聽數(shù)據(jù)(在vue文件中使用后會(huì)自動(dòng)銷毀)// 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() {}總結(jié)

本文主要收錄vue中常用的這幾個(gè)API,如果有興趣學(xué)習(xí)更多,可以參考其官網(wǎng)。希望本文對你有用,并能熟練運(yùn)用到實(shí)際的項(xiàng)目開發(fā)中。

為了方便閱讀理解,本文代碼已經(jīng)上傳Github

文中如有錯(cuò)誤,歡迎在評論區(qū)指正,如果有所幫助,歡迎點(diǎn)贊和關(guān)注。

以上就是Vue常用API、高級API的相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Vue常用API、高級API的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 国产综合色在线视频播放线视 | 国产精品v免费视频 | 91青娱乐在线 | 国内自拍区 | 国产福利在线视频尤物tv | 成人做爰免费网站 | 我看逼逼| 国产精品视频国产永久视频 | 久久香蕉精品成人 | 欧美日韩一区二区三区自拍 | 久久精品国产99国产精品澳门 | 91香蕉在线视频 | 国产精品色| 日本欧美一区二区三区免费不卡 | 亚洲综合第一 | 婷婷精品在线 | 国产精品69白浆在线观看免费 | 婷婷综合社区 | 亚洲无线一二三四区手机 | 国产免费小视频在线观看 | 国产精品一级毛片不收费 | 综合亚洲欧美 | 久久综合色区 | 国产在线精品观看 | 亚洲永久免费视频 | 成人深爱网 | 久久国产精品永久免费网站 | 黑人的逼 | 成人私拍福利视频在线 | 成人夜色香网站在线观看 | 啪啪免费看视频 | 国产福利片在线 易阳 | 国产亚洲99影院 | 免费播放欧美毛片 | 韩日一级毛片 | 99久久婷婷免费国产综合精品 | 高清在线一区二区三区亚洲综合 | 91pao强力打造免费高清 | 国产在热线精品视频国产一二 | 91精选国产 | 久久久久久亚洲精品影院 |