欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2021年02月02日 10:58:12   作者:SandySY  
這篇文章主要介紹了Vue常用API、高級(jí)API的相關(guān)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下

最近手癢癢,玩兒了一下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 更新了
 })

說(shuō)明:

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

擴(kuò)展:

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

mixin

功能:

注冊(cè)一個(gè)混入,影響注冊(cè)之后所有創(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!"

說(shuō)明:

object:一個(gè)vm的屬性或方法
ps:請(qǐng)謹(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

功能:

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

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

說(shuō)明:

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

filter

功能:

用于一些常見(jiàn)的文本格式化和一些規(guī)范數(shù)據(jù)mapping。
用法:

<!-- 在雙花括號(hào)中 -->
{{ message | capitalize }}

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

new Vue({
 // ...
})

說(shuō)明:

過(guò)濾器函數(shù)總接收表達(dá)式的值 (之前的操作鏈的結(jié)果) 作為第一個(gè)參數(shù)。
過(guò)濾器應(yīng)該被添加在 JavaScript 表達(dá)式的尾部,由“管道”符號(hào)指示。

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

directive

功能:

用于注冊(cè)自定義指令。

用法:

<!-- 當(dāng)頁(yè)面加載時(shí),該元素將獲得焦點(diǎn) --> 
<input v-focus>
// 注冊(cè)一個(gè)全局自定義指令 `v-focus`
Vue.directive('focus', {
 // 當(dāng)被綁定的元素插入到 DOM 中時(shí)……
 inserted: function (el) {
  // 聚焦元素
  el.focus()
 }
})
// 注冊(cè)局部指令,組件中也接受一個(gè) directives 的選項(xiàng)
directives: {
 focus: {
  // 指令的定義
  inserted: function (el) {
   el.focus()
  }
 }
}

說(shuō)明:

inserted 只是注冊(cè)指令的其中一個(gè)插值函數(shù),完整的注冊(cè)屬性還可以包括:
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ā)生了改變,也可能沒(méi)有,但是可以通過(guò)比較更新前后的值來(lái)忽略不必要的模板更新。
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 () {}
})

其它簡(jiǎn)單的常用屬性和方法

// console.log(vm.$root); 
vm.$root  //實(shí)例對(duì)象

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

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

vm.$data  //實(shí)例下的data對(duì)象
// 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  //用來(lái)獲取父組件傳遞過(guò)來(lái)的所有屬性
// console.log(vm.$attrs);

vm.$listeners  //用來(lái)獲取父組件傳遞過(guò)來(lái)的所有方法
// console.log(vm.$listeners);

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

vm.$scopedSlots   //用來(lái)訪問(wèn)作用域插槽
// console.log(vm.$scopedSlots);

vm.$refs  //用來(lái)定位DOM元素(使用ref進(jìn)行追蹤)
// console.log(vm.$refs);

vm.$watch  //用于監(jiān)聽(tīng)數(shù)據(jù)(在vue文件中使用后會(huì)自動(dòng)銷毀)
// console.log(vm.$watch);

vm.$emit  //用于派發(fā)事件(常用于數(shù)據(jù)通信)
// console.log(vm.$emit);

vm.$on //用于監(jiān)聽(tīng)事件的派發(fā)
// console.log(vm.$on);

vm.$once  //只監(jiān)聽(tīng)事件一次(之后不監(jiān)聽(tīng))
// console.log(vm.$once);

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

總結(jié)

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

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

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

以上就是Vue常用API、高級(jí)API的相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Vue常用API、高級(jí)API的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue+Element ui實(shí)現(xiàn)樹(shù)形控件右鍵菜單

    Vue+Element ui實(shí)現(xiàn)樹(shù)形控件右鍵菜單

    這篇文章主要為大家詳細(xì)介紹了Vue+Element ui實(shí)現(xiàn)樹(shù)形控件右鍵菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue 2.0的數(shù)據(jù)依賴實(shí)現(xiàn)原理代碼簡(jiǎn)析

    Vue 2.0的數(shù)據(jù)依賴實(shí)現(xiàn)原理代碼簡(jiǎn)析

    本篇文章主要介紹了Vue 2.0的數(shù)據(jù)依賴實(shí)現(xiàn)原理代碼簡(jiǎn)析,主要從初始化的數(shù)據(jù)層面上分析了Vue是如何管理依賴來(lái)到達(dá)數(shù)據(jù)的動(dòng)態(tài)響應(yīng),有興趣的可以了解一下
    2017-07-07
  • vue實(shí)現(xiàn)觸底查詢功能

    vue實(shí)現(xiàn)觸底查詢功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)觸底查詢功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • vue報(bào)錯(cuò)之exports is not defined問(wèn)題的解決

    vue報(bào)錯(cuò)之exports is not defined問(wèn)題的解決

    這篇文章主要介紹了vue報(bào)錯(cuò)之exports is not defined問(wèn)題的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue在取對(duì)象長(zhǎng)度length時(shí)候出現(xiàn)undefined的解決

    vue在取對(duì)象長(zhǎng)度length時(shí)候出現(xiàn)undefined的解決

    這篇文章主要介紹了vue在取對(duì)象長(zhǎng)度length時(shí)候出現(xiàn)undefined的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 一文詳解Vue中渲染器的簡(jiǎn)單實(shí)現(xiàn)

    一文詳解Vue中渲染器的簡(jiǎn)單實(shí)現(xiàn)

    渲染器用于完成渲染操作,比如在瀏覽器平臺(tái)上渲染器可以將虛擬DOM轉(zhuǎn)換為真實(shí)DOM,本文將通過(guò)一個(gè)簡(jiǎn)單例子來(lái)帶大家理解Vue中渲染器的工作過(guò)程,并通過(guò)代碼示例講解的非常詳細(xì),需要的朋友可以參考下
    2024-05-05
  • Vue實(shí)現(xiàn)日歷小插件

    Vue實(shí)現(xiàn)日歷小插件

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)日歷小插件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • Vue 表情包輸入組件的實(shí)現(xiàn)代碼

    Vue 表情包輸入組件的實(shí)現(xiàn)代碼

    這篇文章主要介紹了Vue 表情包輸入組件的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Vue實(shí)現(xiàn)點(diǎn)擊圖片放大顯示功能

    Vue實(shí)現(xiàn)點(diǎn)擊圖片放大顯示功能

    這篇文章主要為大家詳細(xì)介紹了如何利用Vue實(shí)現(xiàn)點(diǎn)擊圖片放大顯示功能,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-03-03
  • Vue2中使用tailwindCss的詳細(xì)教程

    Vue2中使用tailwindCss的詳細(xì)教程

    Tailwind CSS是一個(gè)流行的前端CSS框架,它基于原子設(shè)計(jì)原則,提供了一套預(yù)構(gòu)建的CSS樣式類,旨在幫助開(kāi)發(fā)者快速地創(chuàng)建響應(yīng)式、可定制的用戶界面,本文給大家介紹了Vue2中使用tailwindCss的詳細(xì)教程,需要的朋友可以參考下
    2024-09-09

最新評(píng)論