您好,登錄后才能下訂單哦!
這篇文章主要講解了解決Vue的自定義組件不能使用click方法的問題,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
先貼代碼
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)闆]有加上native,官網(wǎng)對(duì)于native的解釋為:
.native - 監(jiān)聽組件根元素的原生事件。
正確的代碼為:
<my-button @click.native="alert1()" names="刪除" v-bind:item2="btdata"></my-button>
這樣就能成功在自定義標(biāo)簽上綁定事件了
補(bǔ)充知識(shí):Vue中利用component切換組件
我就廢話不多說了,大家還是直接看代碼吧~
<!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',{ //注意無論是哪種方式創(chuàng)建組件,template都只能有一個(gè)唯一的根元素 template: '<h4>組件1</h4>',//指定組件要展示的html結(jié)構(gòu) }) Vue.component('mycom2',{ //注意無論是哪種方式創(chuàng)建組件,template都只能有一個(gè)唯一的根元素 template: '<h4>組件2</h4>',//指定組件要展示的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í)例要控制頁面上的哪個(gè)區(qū)域 data: { //data屬性中存放的是el中要用到的數(shù)據(jù) componentName: 'mycom1' } }); </script> </html>
看完上述內(nèi)容,是不是對(duì)解決Vue的自定義組件不能使用click方法的問題有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。