91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue.js中如何實時監聽input值的變化

發布時間:2022-04-25 16:28:18 來源:億速云 閱讀:3950 作者:iii 欄目:大數據

這篇文章主要講解了“vue.js中如何實時監聽input值的變化”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“vue.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>

結果如圖所示:

vue.js中如何實時監聽input值的變化

當在輸入框輸入文字的時候,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>

實現的效果如圖所示:

vue.js中如何實時監聽input值的變化

感謝各位的閱讀,以上就是“vue.js中如何實時監聽input值的變化”的內容了,經過本文的學習后,相信大家對vue.js中如何實時監聽input值的變化這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

合山市| 商都县| 抚远县| 江津市| 开原市| 垦利县| 葫芦岛市| 鄂尔多斯市| 红桥区| 凤城市| 山丹县| 来宾市| 分宜县| 时尚| 涟源市| 象山县| 织金县| 新兴县| 安国市| 乳山市| 囊谦县| 牙克石市| 栖霞市| 博罗县| 荔浦县| 孟州市| 弋阳县| 鄄城县| 汕头市| 宁德市| 西丰县| 古浪县| 凤山县| 奉贤区| 八宿县| 元谋县| 内黄县| 柞水县| 井冈山市| 科技| 舞阳县|