vue 事件中的 .native


native是什么?

.native - 監聽組件根元素的原生事件。 
主要是給自定義的組件添加原生事件。

官網的解釋:

        你可能想在某個組件的根元素上監聽一個原生事件。可以使用 v-on 的修飾符 .native 。

        通俗點講:就是在父組件中給子組件綁定一個原生的事件,就將子組件變成了普通的HTML標簽,不加'. native'事件是無法觸  發的。

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Document</title>
 6 </head>
 7 <body>
 8     <div id="app">
 9         <button @click.native="clickFn">按鈕</button>
10     </div>
11 <script src='vue.js'></script>
12 <script>
13 
14 
15     new Vue({
16         el:'#app',
17         data:{
18         },
19         methods:{
20             clickFn () {
21               console.log('點擊按鈕了')
22           }
23         }
24     })
25 
26 </script>
27 </body>
28 </html>

  此時點擊頁面中的按鈕無任何反應。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <card @click.native="clickFn">按鈕</card>
    </div>
<script src='vue.js'></script>
<script>

    Vue.component('card',{
        template:'<p>這是card組件<button>按鈕</button></p>'
    })

    new Vue({
        el:'#app',
        data:{
            state:false
        },
        methods:{
            clickFn (e) {
              console.log(e)  //打印出MouseEvent對象
              if (e.target.nodeName === 'IMG') {  // 可以對點擊的target標簽進行判斷
                this.dialogImageUrl = file.target.src
                this.dialogVisible = true
              }
          }
        }
    })

</script>
</body>
</html>

 

總結: .native - 主要是給自定義的組件添加原生事件,可以理解為該修飾符的作用就是把一個vue組件轉化為一個普通的HTML標簽,並且該修飾符對普通HTML標簽是沒有任何作用的。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM