vuejs2.0與1.x版本中怎樣使用js實時訪問input的值的變化


vuejs 2.0中js實時監聽input

在2.0的版本中,vuejs把v-el 和 v-ref 合並為一個 ref 屬性了,可以在組件實例中通過 $refs 來調用。這意味着 v-el:my-element 將寫成這樣: ref="myElement", v-ref:my-component 變成了這樣: ref="myComponent"。綁定在一般元素上時,ref 指DOM元素,綁定在組件上時,ref 為一組件實例。

因為 v-ref 不再是一個指令了而是一個特殊的屬性,它也可以被動態定義了。這樣在和v-for 結合的時候是很有用的:

<p v-for="item in items" v-bind:ref="'item' + item.id"></p>

以前 v-el/v-ref 和 v-for 一起使用將產生一個DOM數組或者組件數組,因為沒法給每個元素一個特定名字。現在你還仍然可以這樣做,給每個元素一個同樣的ref:

<p v-for="item in items" ref="items"></p>

1.x 中不同, $refs 不是響應的,因為它們在渲染過程中注冊/更新。只有監聽變化並重復渲染才能使它們響應。另一方面,設計$refs主要是提供給 js 程序訪問的,並不建議在模板中過度依賴使用它。因為這意味着在實例之外去訪問實例狀態,違背了 Vue 數據驅動的思想。

下面給一個vuejs2.0版本的例子:

<div id="example">
    <input type="text" v-model="items.type1" ref="type1"/>
    <input type="text" v-model="items.type2" ref="type2"/>
    <div class="show">輸入框一的內容:{{items.type1}}</div>
    <div class="show">輸入框二的內容:{{items.type2}}</div>
</div>
<script>
    var example1 = new Vue({
      el: '#example',
      data: {
        items: {
            type1:'第一個輸入框',
            type2:'第二個輸入框'
        }
      },
       ready:function(){
            
        },
        watch:{
            items:{
                handler:function(val,oldval){
                    console.log(this.$refs.type1.value);
                    console.log(this.$refs.type2.value);
                },
                deep:true
            }
        },
      methods:{
        
      }
    })
</script>

結果如圖所示:

當在輸入框輸入文字的時候,js可以實時監聽其指定輸入框文本的值。

vuejs 1.x中js實時監聽input

那么在vuejs 1.x的版本中是如何在js中監聽某個指定的input的value變化的呢?通過如下方式:

<input type="text" v-model="items.type1" v-el:texttype1/>

然后在vuejs中的watch中監聽:

watch:{
    items:{
        handler:function(val,oldval){
            console.log(this.$els.texttype1.value);
        },
        deep:true
    }
}

整體代碼:

<div id="example">
    <input type="text" v-model="items.type1" v-el:texttype1/>
    <input type="text" v-model="items.type2" v-el:texttype2/>
    <div class="show">輸入框一的內容:{{items.type1}}</div>
    <div class="show">輸入框二的內容:{{items.type2}}</div>
</div>
<script>
    var example1 = new Vue({
      el: '#example',
      data: {
        items: {
            type1:'第一個輸入框',
            type2:'第二個輸入框'
        }
      },
       ready:function(){
            
        },
        watch:{
            items:{
                handler:function(val,oldval){
                    console.log(this.$els.texttype1.value);
                },
                deep:true
            }
        },
      methods:{
        
      }
    })
</script>

實現的效果如圖所示:

當在輸入框中輸入文字時,js中實時監聽其變化的值。


免責聲明!

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



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