亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue中v-model的應(yīng)用及使用詳解

 更新時間:2018年06月27日 08:59:15   作者:王子城  
v-model用于表單數(shù)據(jù)的雙向綁定,其實它就是一個語法糖。這篇文章主要介紹了vue中v-model的應(yīng)用,需要的朋友可以參考下

vue中經(jīng)常使用到<input>和<textarea>這類表單元素,vue對于這些元素的數(shù)據(jù)綁定和我們以前經(jīng)常用的jQuery有些區(qū)別。vue使用v-model實現(xiàn)這些標(biāo)簽數(shù)據(jù)的雙向綁定,它會根據(jù)控件類型自動選取正確的方法來更新元素。

    v-model本質(zhì)上是一個語法糖。如下代碼<input v-model="test">本質(zhì)上是<input :value="test" @input="test = $event.target.value">,其中@input是對<input>輸入事件的一個監(jiān)聽:value="test"是將監(jiān)聽事件中的數(shù)據(jù)放入到input,下面代碼是v-model的一個簡單的例子。在這邊需要強調(diào)一點,v-model不僅可以給input賦值還可以獲取input中的數(shù)據(jù),而且數(shù)據(jù)的獲取是實時的,因為語法糖中是用@input對輸入框進(jìn)行監(jiān)聽的??梢栽谌缦耫iv中加入<p>{{ test}}</p>獲取input數(shù)據(jù),然后去修改input中數(shù)據(jù)會發(fā)現(xiàn)<p></p>中數(shù)據(jù)隨之改變。

<div id="app">
  <input v-model="test">
  <!-- <input :value="test" @input="test= $event.target.value"> --><!--語法糖-->
</div>
<script src="/resources/js/vue.js"></script>
<script>
  new Vue({
    el: '#app',
    data: {
      test: '這是一個測試'
    }
  });
</script>

1.v-model在input的下拉框、單選按鈕、復(fù)選框中的應(yīng)用

    如下面代碼,分別是v-model在input不同的組件中的應(yīng)用,但是大體用法相同。注意:像下面代碼中復(fù)選框這樣需要接收多條數(shù)據(jù)的情況下,在data里面應(yīng)該由數(shù)組與其對應(yīng)二不是字符串。

    這里有一個值綁定的問題,不管是下拉框或者單選按鈕還是復(fù)選框,我們都可以在對應(yīng)的標(biāo)簽內(nèi)設(shè)置value。以下拉框為例,我們在<option>中添加了vulue=“A被選”,當(dāng)我們選擇第一個下拉框A的時候,在selected中的字符串為‘A被選',如果我們不在<option>中設(shè)置value值的話那么selected中的字符串將是<option>中的值‘A'。

    這里還有一個和vue無關(guān)的問題,比較簡單,但是由于平時主要做后臺java開發(fā)沒太注意這個前端問題。以下面的單選按鈕代碼為例,<label>標(biāo)簽內(nèi)有一個for元素與input中的id值對應(yīng)(兩個值相同),剛開始不太理解為什么這么寫,這個對前端人員來說應(yīng)該是一個很簡單的問題。這樣寫的目的沒有其它任何作用,只是label元素為鼠標(biāo)改進(jìn)了可用性,在點擊label的時候也相當(dāng)于點擊了對應(yīng)的input控件,點擊label標(biāo)簽也可以觸發(fā)input標(biāo)簽控件。例如單選按鈕在加了for之后點擊small也可以選擇對應(yīng)按鈕,但是如果不加for是沒有任何反應(yīng)的。

<!--下拉框-->
<div id="app">
  <select v-model="selected">
    <option value="A被選">A</option>
    <option value="B被選">B</option>
    <option value="C被選">C</option>
  </select>
  <span>Selected: {{ selected }}</span>
</div>
<script src="/resources/js/vue.js"></script>
<script>
  new Vue({
    el: '#app',
    data: {
      selected: ''
    }
  });
</script>

<!--單選按鈕-->
<div id="app">
  <input type="radio" id="small" value="small_value" v-model="picked">
  <label for="small">small</label>
  <br>
  <input type="radio" id="big" value="big_value" v-model="picked">
  <label for="big">big</label>
  <br>
  <span>Picked: {{ picked }}</span>
</div>
<script src="/resources/js/vue.js"></script>
<script>
  new Vue({
    el: '#app',
    data: {
      picked: ''
    }
  })
</script>

<!--復(fù)選框-->
<div id="app">
  <input type="checkbox" id="one" value="value_one" v-model.lazy="checkedNames">
  <label for="one">選項一</label>
  <input type="checkbox" id="two" value="value_two" v-model.lazy="checkedNames">
  <label for="two">選項二</label>
  <input type="checkbox" id="three" value="value_three" v-model.lazy="checkedNames">
  <label for="three">選項三</label>
  <br>
  <span>Checked names: {{ checkedNames }}</span>
</div>
<script src="/resources/js/vue.js"></script>
<script>
  new Vue({
    el: '#app',
    data: {
      checkedNames: []
    }
  })
</script>

2.v-model修飾符

    v-model也可以和.lazy、.trim和.number這些修飾符一起使用。

  <!-- 在每次 input 事件觸發(fā)后將輸入框的值與數(shù)據(jù)進(jìn)行同步,添加 lazy 修飾符,從而轉(zhuǎn)變?yōu)槭褂?change 事件進(jìn)行同步 -->
  <input v-model.lazy="msg" >
  <!--去除字符串首尾的空格-->
  <input v-model.trim="msg">
  <!--將數(shù)據(jù)轉(zhuǎn)化為值類型-->
  <input v-model.number="age" type="number">

    .trim和.number的用法比較簡單,這里就不做過多解釋。.lazy相當(dāng)于一個延遲加載的過程。在上面我們講過<input v-model="test">相當(dāng)于一個語法糖<input :value="test" @input="test = $event.target.value">,<input v-model.lazy="msg" >則相當(dāng)將input的實時更新改為一個change事件,v-model.lazy只有當(dāng)焦點移除input時才會觸發(fā)事件。下圖1位v-model效果,圖2位v-model.lazy效果。

下面在單獨給大家介紹下vue中v-model使用

v-model用于表單數(shù)據(jù)的雙向綁定,其實它就是一個語法糖,這個背后就做了兩個操作:

  1. v-bind綁定一個value屬性

  2. v-on指令給當(dāng)前元素綁定input事件

自定義組件使用v-model,應(yīng)該有以下操作:

1. 接收一個value prop

2. 觸發(fā)input事件,并傳入新值

在原生表單元素中:

<input v-model="inputValue">

相當(dāng)于

<input v-bind:value="inputValue" v-on:input="inputValue = $event.target.value">

在自定義組件中

<my-component v-model="inputValue"></my-component>

相當(dāng)于

<my-component v-bind:value="inputValue" v-on:input="inputValue = argument[0]"></my-component>

這個時候,inputValue接受的值就是input事件的回調(diào)函數(shù)的第一個參數(shù),所以在自定義組件中,要實現(xiàn)數(shù)據(jù)綁定,還需要$emit去觸發(fā)input的事件。

this.$emit('input', value)

總結(jié)

以上所述是小編給大家介紹的vue中v-model的應(yīng)用及使用詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vuex的使用及持久化state的方式詳解

    vuex的使用及持久化state的方式詳解

    這篇文章主要介紹了vuex的使用及持久化state的方式詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • vue-cli項目修改文件熱重載失效的解決方法

    vue-cli項目修改文件熱重載失效的解決方法

    今天小編就為大家分享一篇vue-cli項目修改文件熱重載失效的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vuex直接修改state、commit和dispatch修改state的用法及區(qū)別說明

    vuex直接修改state、commit和dispatch修改state的用法及區(qū)別說明

    這篇文章主要介紹了vuex直接修改state、commit和dispatch修改state的用法及區(qū)別說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • vue項目中使用axios上傳圖片等文件操作

    vue項目中使用axios上傳圖片等文件操作

    axios 是一個基于Promise 用于瀏覽器和 nodejs 的 HTTP 客戶端。這篇文章主要給大家介紹了vue項目中使用axios上傳圖片等文件操作,需要的朋友參考下吧
    2017-11-11
  • 關(guān)于VUE點擊父組件按鈕跳轉(zhuǎn)到子組件的問題及解決方案

    關(guān)于VUE點擊父組件按鈕跳轉(zhuǎn)到子組件的問題及解決方案

    本文主要介紹了在Vue框架中,如何通過父組件的點擊事件打開子組件中的彈窗并展示表格內(nèi)容,主要步驟包括在父組件中定義數(shù)據(jù)屬性,創(chuàng)建并定義子組件的彈窗和表格內(nèi)容,通過props屬性和自定義事件實現(xiàn)父子組件間的數(shù)據(jù)傳遞和方法調(diào)用
    2024-10-10
  • VUE div click無效的問題及解決

    VUE div click無效的問題及解決

    這篇文章主要介紹了VUE div click無效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue計算屬性與偵聽器和過濾器超詳細(xì)介紹

    Vue計算屬性與偵聽器和過濾器超詳細(xì)介紹

    這篇文章主要介紹了Vue計算屬性與偵聽器和過濾器,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • vue限制文本輸入框只允許輸入字母、數(shù)字、禁止輸入特殊字符

    vue限制文本輸入框只允許輸入字母、數(shù)字、禁止輸入特殊字符

    這篇文章主要介紹了vue限制文本輸入框只允許輸入字母、數(shù)字、不允許輸入特殊字符,通過監(jiān)聽表單輸入的內(nèi)容,使用方法的缺陷,本文通過實例代碼介紹的非常詳細(xì),需要的朋友參考下吧
    2023-10-10
  • vue內(nèi)置組件Transition的示例詳解

    vue內(nèi)置組件Transition的示例詳解

    這篇文章主要介紹了vue內(nèi)置組件Transition的詳解,簡單地說,就是當(dāng)元素發(fā)生變化,比如消失、顯示時,添加動畫讓它更自然過渡,它是vue內(nèi)置組件,不需要引入注冊就可以直接使用,本文通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09
  • 實現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式

    實現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式

    今天小編就為大家分享一篇實現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11

最新評論