1. 程式人生 > >vue 事件中的 .native

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標籤是沒有任何作用的。