溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

解決Vue的自定義組件不能使用click方法的問題

發(fā)布時(shí)間:2020-07-30 10:26:03 來源:億速云 閱讀:388 作者:小豬 欄目:開發(fā)技術(shù)

這篇文章主要講解了解決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è)資訊頻道。

向AI問一下細(xì)節(jié)

免責(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)容。

AI