2 回答

TA貢獻1824條經(jīng)驗 獲得超5個贊
事件名稱不允許用駝峰式,fiddle里看不出來,在瀏覽器里Vue會發(fā)出警告中斷執(zhí)行,模板和觸發(fā)的方法名稱都改成小寫就可以成功,親測可行。
// template<child-com @handle-tip="handleTip" :param="childParam"></child-com>// script methods: { handleTip: function () { this.$emit('handle-tip', 'haha') } }

TA貢獻1801條經(jīng)驗 獲得超8個贊
事件名
不同于組件和 prop,事件名不存在任何自動化的大小寫轉(zhuǎn)換。而是觸發(fā)的事件名需要完全匹配監(jiān)聽這個事件所用的名稱。舉個例子,如果觸發(fā)一個 camelCase 名字的事件:
this.$emit('myEvent')
則監(jiān)聽這個名字的 kebab-case 版本是不會有任何效果的:
<my-component v-on:my-event="doSomething"></my-component>
不同于組件和 prop,事件名不會被用作一個 JavaScript 變量名或?qū)傩悦?,所以就沒有理由使用 camelCase 或 PascalCase 了。并且 v-on 事件監(jiān)聽器在 DOM 模板中會被自動轉(zhuǎn)換為全小寫 (因為 HTML 是大小寫不敏感的),所以 v-on:myEvent 將會變成 v-on:myevent——導(dǎo)致 myEvent 不可能被監(jiān)聽到。
因此,我們推薦你始終使用 kebab-case 的事件名。
添加回答
舉報