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

詳解Vue的sync修飾符

 更新時(shí)間:2021年05月15日 10:46:39   作者:lovin  
.sync修飾符算是Vue的所有修飾符中較難理解的一個(gè),本篇文章就帶你走近.sync的世界,深入理解后會(huì)發(fā)現(xiàn),其實(shí)也就那么回事。修飾符和指令息息相關(guān),下面從指令 ->修飾符->.sync修飾符由淺入深地來講解 .sync的含義及用法。

1 、指令

指令即 Directive,從字面意思理解就是我告訴你要做什么,就是發(fā)送了一個(gè)指令,然后由接收指令的人去做就好了。在 Vue 中的指令有個(gè)統(tǒng)一好認(rèn)的格式,就是以 v- 開頭的就是指令,如:

<div v-text="x"> </div> //v-text指定標(biāo)簽文本指令
<div v-on:click="add"> <div> //v-on事件綁定指令

但并不是所有的指令都以 v- 開頭,對(duì)于一些簡寫,也是指令,如

<img :src="x"> </img> //v-bind:src 的簡寫
<button @click="add"> </button> //v-on:click 的簡寫

2 、修飾符

修飾符是與指令中的事件處理指令 v-on 息息相關(guān)的一個(gè)語法糖,所謂語法糖就是很 sweet,簡單好用,在編程界就是能幫你做好的都幫你做了,只剩最簡單的事留給你做。

在事件處理程序中,有一些非常常見的需求,例如 event.preventDefault() 阻止默認(rèn)事件和 event.stopPropagation()阻止事件冒泡等等。因此 Vue 就把這些事件處理過程中常見的需求幫我們處理好了,在我們需要時(shí)告訴 Vue 一聲,它就會(huì)自動(dòng)幫我們阻止默認(rèn)事件、阻止事件冒泡等。那么我們告訴 Vue 的途徑就是 Vue 提供給我們的修飾符,修飾符是由點(diǎn)開頭的指令后綴來表示的

以阻止 <a> 標(biāo)簽的點(diǎn)擊默認(rèn)刷新頁面事件的 preventDefault 方法示例如下:

普通做法

<a href="" v-on:click=" rel="external nofollow" pe($event)">Vue點(diǎn)擊鏈接</a> //vue中訪問原始的DOM事件,可以用特殊變量 $event 把它傳入方法,在原始 HTML 中是 event
// ... 
methods: {
    pe(e){
        e.preventDefault()
    }
}

使用修飾符

<a v-on:click.prevent>Vue點(diǎn)擊鏈接</a> //prevent修飾符就等同于上述的 e.preventDefault()

由上述的小例可以看出,修飾符是不是個(gè)語法糖,幫我們把常用的需求提前寫好了,用的時(shí)候說一聲就行。當(dāng)有事件處理程序時(shí)直接在后面繼續(xù)寫即可,如下:

<a href="" v-on:click.prevent=" rel="external nofollow" pp">Vue點(diǎn)擊鏈接</a>
// ... 
methods: {
    pp(){
        console.log('不跳轉(zhuǎn)頁面執(zhí)行事件')
    }
}

修飾符是有順序地執(zhí)行的,如上述的 v-on:click.prevent="pp",意思就是在點(diǎn)擊時(shí),先執(zhí)行修飾符 prevent 的阻止默認(rèn)事件,然后再執(zhí)行后面的 pp 事件處理函數(shù)。

修飾符幾乎是和事件 event 的相關(guān)處理函數(shù)一一對(duì)應(yīng)的,根據(jù)事件的不同,對(duì)應(yīng)不同事件的修飾符,如下所示分為幾大類:

修飾符的來源和含義就是上述所述,至于具體有哪些,在實(shí)際用到時(shí)可去官網(wǎng)查找所需,有兩個(gè)最最常用的需要記住,即 @click.stop 是阻止事件冒泡,@click.prevent 是阻止默認(rèn)事件,@keypress.enter 是按鍵為回車事件。

3、 .sync 修飾符

.sync 修飾符相對(duì)來說比較特殊,因?yàn)槠洳皇鞘录?event 原有的事件處理相關(guān)函數(shù)的演變,而是 Vue 自己定義的一個(gè)修飾符,如上述的修飾符分類中也將 .sync 分類為自定義事件的修飾符,那么這個(gè)自定義事件到底是什么事件呢?

這個(gè)事件對(duì)應(yīng)的是 eventBus 事件,eventBus 事件是 MVC 中的一個(gè)模式,簡單來說就是發(fā)布和訂閱的過程,就是說有兩方,甲方負(fù)責(zé)始終監(jiān)聽某個(gè)事件,乙方負(fù)責(zé)在需要的時(shí)候觸發(fā)這個(gè)事件,甲方在監(jiān)聽到事件被觸發(fā)時(shí)就執(zhí)行某些操作。甲方就是訂閱,乙方就是發(fā)布,雙方就是發(fā)布和訂閱模式。

那么在 Vue 中在什么時(shí)候會(huì)需要用到這種情況呢?

就是在 Vue 的組件在接受外部數(shù)據(jù) props 時(shí),Vue 規(guī)定,子組件在通過 props 接受外部數(shù)據(jù)后只有使用該數(shù)據(jù)的權(quán)利,但沒有修改該屬性的權(quán)利。因?yàn)?,如果子組件修改了外部傳來的數(shù)據(jù),這樣一來子組件和使用其的父文件都可以改來改去,在父組件和子組件都沒有明顯的改動(dòng)來源,到最后都不知道這個(gè)數(shù)據(jù)是誰改的了,數(shù)據(jù)就不好控制了。因此 Vue 就規(guī)定組件只能有權(quán)使用 props 的屬性,不得自己改變,那么若其想要改變,就必須通知該數(shù)據(jù)的真正擁有者改變,也就是使用該組件的父文件。

其使用的通知方式就是 eventBus 發(fā)布和訂閱模式。

不使用 .sync

子組件觸發(fā)事件,事件名格式必須是 update:myPropName ,用 $emit 函數(shù)觸發(fā)

this.$emit('update:title', newTitle) //newTitle就是你想要修改props數(shù)據(jù)修改后的值

父組件可以監(jiān)聽那個(gè)事件并根據(jù)需要更新一個(gè)本地的數(shù)據(jù)屬性

<myconponent :title="Ptitle" @update:title="Ptitle = $event" ></myconponent>
//在父組件中監(jiān)聽該事件,該事件觸發(fā)后傳遞的值以 $event 接收,$event === newTitle ,Ptitle是父組件的數(shù)據(jù)

或者是定義的接受函數(shù)的參數(shù)

<myconponent :title="Ptitle" @update:title="val => Ptitle = val" ></myconponent>
//這時(shí)接收的值作為函數(shù)的參數(shù)

使用 .sync

上述的過程在實(shí)際需求中很常用,因此 Vue 就將父組件的監(jiān)聽定義成了一個(gè)傳值時(shí)的修飾符,為 .sync ,上述代碼使用 .sync 修飾符后為:

子組件(是一樣的)

this.$emit('update:title', newTitle)

父組件

<myconponent :title.sync="Ptitle"></myconponent> //等同于上面的傳值并監(jiān)聽

是不是很 sweet 呢?

4 、總結(jié)

.sync 的用法規(guī)則

1.組件不能修改 props 外部數(shù)據(jù)

2.this.$emit 可以觸發(fā)事件,并傳參

3.$event 可以獲取 $emit 的參數(shù)

以上就是詳解Vue的sync修飾符的詳細(xì)內(nèi)容,更多關(guān)于Vue的sync修飾符的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue中Promise的使用方法詳情

    vue中Promise的使用方法詳情

    這篇文章主要介紹了vue中Promise的使用方法詳情,Promise可以說是異步編程的一種解決方法,主要是為了解決代碼亂的情景而出現(xiàn)的,下文介紹其具體用法,需要的小伙伴可以參考一下
    2022-03-03
  • vue中是怎樣監(jiān)聽數(shù)組變化的

    vue中是怎樣監(jiān)聽數(shù)組變化的

    這篇文章主要介紹了vue中是怎樣監(jiān)聽數(shù)組變化的,幫助大家更好的理解和學(xué)習(xí)vue,感興趣的朋友可以了解下
    2020-10-10
  • 解決vuecli3.0熱更新失效的問題

    解決vuecli3.0熱更新失效的問題

    今天小編就為大家分享一篇解決vuecli3.0熱更新失效的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue-cli3.0之配置productionGzip方式

    vue-cli3.0之配置productionGzip方式

    這篇文章主要介紹了vue-cli3.0之配置productionGzip方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue側(cè)滑菜單組件——DrawerLayout

    Vue側(cè)滑菜單組件——DrawerLayout

    本文介紹一個(gè)簡單的DrawerLayout(類似Android的DrawerLayout)布局組件的實(shí)現(xiàn),基于Vue.js側(cè)滑菜單組件的實(shí)現(xiàn)代碼大家通過本文一起學(xué)習(xí)吧
    2017-12-12
  • 如何通過shell腳本自動(dòng)生成vue文件詳解

    如何通過shell腳本自動(dòng)生成vue文件詳解

    這篇文章主要給大家介紹了關(guān)于如何通過shell腳本自動(dòng)生成vue文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Vue?非常實(shí)用的自定義指令分享

    Vue?非常實(shí)用的自定義指令分享

    這篇文章主要介紹了Vue?非常實(shí)用的自定義指令分享,Vue自定義指令有全局注冊(cè)和局部注冊(cè)兩種方式,在?Vue,除了核心功能默認(rèn)內(nèi)置的指令?(?v-model?和?v-show?),Vue?也允許注冊(cè)自定義指令,下文小編給大家分享那些常用到的Vue自定義指令
    2022-02-02
  • AntV F2和vue-cli構(gòu)建移動(dòng)端可視化視圖過程詳解

    AntV F2和vue-cli構(gòu)建移動(dòng)端可視化視圖過程詳解

    這篇文章主要介紹了AntV F2和vue-cli構(gòu)建移動(dòng)端可視化視圖過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • petite?vue的使用示例詳解

    petite?vue的使用示例詳解

    這篇文章主要為大家介紹了petite?vue的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • vue使用fengMap速度慢的原因分析

    vue使用fengMap速度慢的原因分析

    這篇文章主要介紹了vue使用fengMap速度慢的原因分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評(píng)論