Vue的自定義組件不能使用click方法的解決
先貼代碼
var myButton = Vue.extend({//設(shè)置標(biāo)簽 props: ['names', 'item2'],//names為按鈕名,item2為數(shù)據(jù) template: '<span><span v-for="obj in item2" v-if="obj.name==names" v-html="obj.code"></span></span>' }) Vue.component('my-button', myButton);//注冊(cè)組件
這是上篇博客的自定義按鈕權(quán)限的代碼,然后調(diào)用代碼:
<my-button names="修改" v-bind:item2="btdata"></my-button>
當(dāng)你在這個(gè)標(biāo)簽上加@click事件的時(shí)候報(bào)錯(cuò),原因是因?yàn)闆](méi)有加上native,官網(wǎng)對(duì)于native的解釋為:
.native - 監(jiān)聽(tīng)組件根元素的原生事件。
正確的代碼為:
<my-button @click.native="alert1()" names="刪除" v-bind:item2="btdata"></my-button>
這樣就能成功在自定義標(biāo)簽上綁定事件了
補(bǔ)充知識(shí):Vue中利用component切換組件
我就廢話不多說(shuō)了,大家還是直接看代碼吧~
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <script src="vue.js"></script> </head> <body> <div id="app"> <a href="#" rel="external nofollow" rel="external nofollow" @click="componentName='mycom1'">組件1</a> <a href="#" rel="external nofollow" rel="external nofollow" @click="componentName='mycom2'">組件2</a> <component :is="componentName"></component> </div> </body> <script> Vue.component('mycom1',{ //注意無(wú)論是哪種方式創(chuàng)建組件,template都只能有一個(gè)唯一的根元素 template: '<h3>組件1</h3>',//指定組件要展示的html結(jié)構(gòu) }) Vue.component('mycom2',{ //注意無(wú)論是哪種方式創(chuàng)建組件,template都只能有一個(gè)唯一的根元素 template: '<h3>組件2</h3>',//指定組件要展示的html結(jié)構(gòu) }) //創(chuàng)建一個(gè)vue實(shí)例 //當(dāng)我們導(dǎo)入包之后,在瀏覽器的內(nèi)存中就多了一個(gè)vue構(gòu)造函數(shù) var vm = new Vue({ el: '#app',//表示當(dāng)前我們new的這個(gè)vue實(shí)例要控制頁(yè)面上的哪個(gè)區(qū)域 data: { //data屬性中存放的是el中要用到的數(shù)據(jù) componentName: 'mycom1' } }); </script> </html>
以上這篇Vue的自定義組件不能使用click方法的解決就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue使用$emit實(shí)現(xiàn)同步調(diào)用
這篇文章主要介紹了vue使用$emit實(shí)現(xiàn)同步調(diào)用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04詳解Vue如何進(jìn)行表單聯(lián)動(dòng)與級(jí)聯(lián)選擇
表單聯(lián)動(dòng)和級(jí)聯(lián)選擇是Vue.js中常見(jiàn)的功能,在下面的文章中,我們將討論如何在Vue.js中實(shí)現(xiàn)表單聯(lián)動(dòng)和級(jí)聯(lián)選擇,感興趣的小伙伴可以了解一下2023-06-06