Vue | 一對(duì)基友

每天一遍提醒自己增強(qiáng)自身抵抗力霞幅,多喝熱水漠吻,注意身體。

介紹完 兩對(duì)cp 后司恳,今天來(lái)看看一對(duì)基友的故事侥猩。

在 Vue 中有個(gè)名為 methods 的字段,這貨通常是要搭配 v-on 來(lái)一起使用抵赢。

兩個(gè)搞到一塊可以實(shí)現(xiàn)術(shù)語(yǔ)喚為 事件監(jiān)聽 的東西欺劳。


來(lái)波回憶殺,看看原生的 JavaScript 是如何進(jìn)行事件監(jiān)聽的铅鲤?

const demo = document.querySelector('#demo')
demo.onclick = () => {
    console.log("mama划提,我被人點(diǎn)了。嚶嚶嚶邢享。")
}

看上去不大高端鹏往,喚 addEventListener 來(lái)看看。

const demo = document.querySelector('#demo')
addEventListener('click', () => {
    console.log("mama骇塘,我被人點(diǎn)了伊履。嚶嚶嚶。")
})

emm款违,有點(diǎn)樣子了唐瀑。

通過(guò)上面的一波回憶,要來(lái)監(jiān)聽事件可以提取下列步驟:

  • 找到要監(jiān)聽誰(shuí)插爹? || 監(jiān)聽對(duì)象
  • 對(duì)監(jiān)聽到的事件做何反應(yīng)哄辣? || 響應(yīng)

簡(jiǎn)言之,事件監(jiān)聽就是:某元素發(fā)生了什么事情赠尾,我要做出相應(yīng)的反應(yīng)證明我不是吃干飯的力穗。


來(lái)看看在 Vue 的地盤事件監(jiān)聽是怎么的一個(gè)玩法?

<h1>{{cemcoe}}</h1>
<button v-on:click="qinqin">qinqin</button>
<button v-on:click="baobao">baobao</button>

v-on 監(jiān)聽事件气嫁,起到的是找到監(jiān)聽元素的作用当窗;methods 提供具體的應(yīng)對(duì)策略,被打要不要被打回去寸宵,還是以理服人崖面。

const demo = document.querySelector('#demo')
// 老兄,找元素的事情交給我 v-on
addEventListener('click', () => {
// 回調(diào)函數(shù)就交給 methods 好了
    console.log("mama邓馒,我被人點(diǎn)了嘶朱。嚶嚶嚶。")
})

這個(gè)東西還有語(yǔ)法糖 v-on:click === @click

用上語(yǔ)法糖光酣,有點(diǎn)簡(jiǎn)潔的寫法:

<h1>{{cemcoe}}</h1>
<button @click="qinqin">qinqin</button>
<button @click="baobao">baobao</button>

具體的 qinqin 和 baobao 函數(shù)這里就不實(shí)現(xiàn)了疏遏,當(dāng)偽代碼看。


通過(guò)上面的一番瞎掰,可以知道 methods 中其實(shí)是原先 addEventListener 的回調(diào)函數(shù)财异,函數(shù)肯定要有參數(shù)才能發(fā)揮它的魅力倘零。

關(guān)于參數(shù)的問(wèn)題:

  • 如果方法(函數(shù))不需要參數(shù),那方法后的 () 可以不寫
    · 若方法本身有參數(shù)戳寸,會(huì)默認(rèn)將原生事件 event 傳進(jìn)去
  • 同時(shí)傳某個(gè)參數(shù)和 event 時(shí)呈驶,通過(guò) $event 傳進(jìn)去

這個(gè)關(guān)于 event 的一些東西有空再寫。


下面來(lái)看一些例子疫鹊,正常的邏輯

<button @click="fn(‘cemcoe’)">點(diǎn)我</button>

// ---methods---
fn (a) { console.log(a) }

這是乖孩子袖瞻,方法有一個(gè)函數(shù),那么在使用時(shí)就規(guī)規(guī)矩矩地傳給它一個(gè)參數(shù)拆吆,合作愉快聋迎。


那遇到就是叛逆,就是要彰顯與眾不同枣耀,就是不傳參數(shù)且不加括號(hào)霉晕,會(huì)怎么樣?下面是點(diǎn)三次按鈕的結(jié)果捞奕。

<button @click="fn">點(diǎn)我</button>

// ---methods---
fn (a) { console.log(a) }
MouseEvent

在事件定義時(shí)牺堰,寫方法時(shí)省略小括號(hào),但是方法本身需要參數(shù)颅围,這時(shí)Vue會(huì)默認(rèn)將瀏覽器生產(chǎn)的 event 事件對(duì)象作為參數(shù)傳入方法中伟葫。

下面來(lái)看一個(gè)方法定義時(shí),需要 event 對(duì)象谷浅,同時(shí)需要其他參數(shù)的例子:

<button @click="fn('cemcoe', $event)">點(diǎn)我</button>
//---methods---
 fn (name, event) {
        console.log(name, event)
}
// cemcoe MouseEvent

大概就是這個(gè)樣子扒俯,傳參時(shí)使用 $event 傳遞事件本身。


原生的 事件監(jiān)聽 會(huì)有事件冒泡等問(wèn)題一疯,Vue 為這些問(wèn)題提供了解決方案,術(shù)語(yǔ)叫做修飾符夺姑。換成大白話就是加點(diǎn)加狀態(tài)墩邀。

<div @click="divClick">
    <button @click="btnClick">
        button
    </button>
</div>

//---methods---
divClick() {
    console.log("div")
},
btnClick() {
    console.log("btn")
}

當(dāng)點(diǎn)擊 button 時(shí)會(huì)發(fā)現(xiàn)控制臺(tái)會(huì)打印 div 和 btn,也就是說(shuō)盏浙,兩個(gè)點(diǎn)擊都被激活眉睹,這就是事件冒泡。

阻止冒泡废膘,Vue 可以使用修飾符 .stop

<div @click.stop="divClick">
    <button @click="btnClick">
        button
    </button>
</div>

//---methods---
divClick() {
    console.log("div")
},
btnClick() {
    console.log("btn")
}

修飾符的使用方法如上例 竹海,直接在事件監(jiān)聽后加修飾符。


這里有一些其他修飾符:

  • stop 阻止冒泡 event.stopPropagation()
  • prevent 阻止默認(rèn)事件 event.preventDefault()
  • keyCode 特定按鍵觸發(fā)
  • once 執(zhí)行一次回調(diào)

關(guān)于 v-on 和 methods 的故事告一段落丐黄。

這里是連載 化學(xué)小子的前端實(shí)驗(yàn)冊(cè) 的第 19 篇斋配,歡迎關(guān)注。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市艰争,隨后出現(xiàn)的幾起案子坏瞄,更是在濱河造成了極大的恐慌,老刑警劉巖甩卓,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鸠匀,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡逾柿,警方通過(guò)查閱死者的電腦和手機(jī)缀棍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)机错,“玉大人爬范,你說(shuō)我怎么就攤上這事≌毖” “怎么了坦敌?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)痢法。 經(jīng)常有香客問(wèn)我狱窘,道長(zhǎng),這世上最難降的妖魔是什么财搁? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任蘸炸,我火速辦了婚禮,結(jié)果婚禮上尖奔,老公的妹妹穿的比我還像新娘搭儒。我一直安慰自己,他們只是感情好提茁,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布淹禾。 她就那樣靜靜地躺著,像睡著了一般茴扁。 火紅的嫁衣襯著肌膚如雪铃岔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天峭火,我揣著相機(jī)與錄音毁习,去河邊找鬼。 笑死卖丸,一個(gè)胖子當(dāng)著我的面吹牛纺且,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播稍浆,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼载碌,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼猜嘱!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起恐仑,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤泉坐,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后裳仆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體腕让,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年歧斟,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了纯丸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡静袖,死狀恐怖觉鼻,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情队橙,我是刑警寧澤坠陈,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站捐康,受9級(jí)特大地震影響仇矾,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜解总,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一贮匕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧花枫,春花似錦刻盐、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至佳簸,卻和暖如春供屉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背溺蕉。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留悼做,地道東北人疯特。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像肛走,于是被迫代替她去往敵國(guó)和親漓雅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容