vue 2.0組件與v-model詳解
前言
大家可能乍一看這個標(biāo)題,可能會有疑問:v-model和組件也能扯到一起?在打算寫這篇文章的時候,也是這么想的。咱們按簡歷的那一套STAR法則來梳理一下這篇文章:
情景【Situation】:
編寫通用的輸入組件時,子組件要綁定到父組件的某個變量上dataA,當(dāng)父組件要拿到自組件的值時不能通過this.$children.xxx
取值然后付給dataA,
而是父組件可以直接this.dataA
就可以取到當(dāng)前子組件最新值。
任務(wù)【Task】:
實(shí)現(xiàn)在父組件直接this.dataA就可以取到當(dāng)前子組件最新值。
行動【Action】:
首先要了解v-model這個指令,許多認(rèn)真閱讀過完整vue文檔的同學(xué)可能已經(jīng)知道了關(guān)于v-model。
v-model官方給出的說發(fā)是:這其實(shí)是一個簡寫的形式,v-model實(shí)際執(zhí)行的是下面的綁定:
<input type="text" v-bind:value="dataA" v-on:input="dataA = $event.target.value" />
v-model是動態(tài)綁定值到value,然后監(jiān)聽input的inpit事件獲取值后賦給dataA的一個過程。
在說一下input的value屬性,在組件內(nèi)部要定義一個value的props屬性,以便能夠動態(tài)綁定上父組件傳過來的值;
組件內(nèi)部還要做一件事情:
動態(tài)計(jì)算(獲取和設(shè)置)currentValue的值,用到了vue的對象的get和set函數(shù);
講到這里,我們就可以解決上面的問題了;
首先定義一個通用輸入組件:
Vue.component('my-component',{ template:'<div><input type="text" type="text" v-model="currentValue"/></div>', data:function(){ return { // 雙向綁定值-必須 currentValue:this.value } }, props:['value'],// 設(shè)置value為props屬性-必須 computed:{ currentValue: { // 動態(tài)計(jì)算currentValue的值 get:function() { return this.value; }, set:function(val) { this.$emit('input', val); } } } })
在Html里綁定到vue實(shí)例的一個字段上;
<div id="demo_01"> <my-component v-for="(val,key) in postData" v-model="postData[key]"></my-component> <button @click="showValue">打印對象值</button> </div>
實(shí)例里寫一個方法
打印一下我們綁定的值;
var demo_01 = new Vue({ el:'#demo_01', data:{ postData:{ name:'李雷', age:'80', describ:'這是一個傳奇的人物' } }, methods:{ showValue:function(){ console.log(this.postData) } } });
是不是以后就不用繁瑣冗長的this.$children.xxx
取值方式了?
結(jié)果【Result】:
提供了有效的解決了關(guān)于輸入類組件取值方案,并且已經(jīng)部署實(shí)施。
總結(jié)
以上就是關(guān)于vue2.0 組件和v-model的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的幫助。
- 在Vue2中v-model和.sync區(qū)別解析
- vue2和vue3組件v-model區(qū)別詳析
- Vue2子組件綁定 v-model,實(shí)現(xiàn)父子組件通信方式
- vue2中如何自定義組件的v-model
- Vue v-model相關(guān)知識總結(jié)
- vue2 v-model/v-text 中使用過濾器的方法示例
- Vue2.0利用 v-model 實(shí)現(xiàn)組件props雙向綁定的優(yōu)美解決方案
- vue2 如何實(shí)現(xiàn)div contenteditable=“true”(類似于v-model)的效果
- vue2與vue3雙向數(shù)據(jù)綁定的區(qū)別說明
- vue 2 實(shí)現(xiàn)自定義組件一到多個v-model雙向數(shù)據(jù)綁定的方法(最新推薦)
相關(guān)文章
vue實(shí)現(xiàn)表單未編輯或未保存離開彈窗提示功能
這篇文章主要介紹了vue實(shí)現(xiàn)表單未編輯或未保存離開彈窗提示功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04vue.js中proxyTable 轉(zhuǎn)發(fā)請求的實(shí)現(xiàn)方法
今天小編就為大家分享一篇vue.js中proxyTable 轉(zhuǎn)發(fā)請求的實(shí)現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09VUE識別訪問設(shè)備是pc端還是移動端的實(shí)現(xiàn)步驟
經(jīng)常在項(xiàng)目中會有支持pc與手機(jī)端需求,并且pc與手機(jī)端是兩個不一樣的頁面,這時就要求判斷設(shè)置,下面這篇文章主要給大家介紹了關(guān)于VUE識別訪問設(shè)備是pc端還是移動端的相關(guān)資料,需要的朋友可以參考下2023-05-05如何利用vue+element?ui實(shí)現(xiàn)好看的登錄界面
最近做了個最基礎(chǔ)的ElementUI登錄頁,適合新手查看,所以下面這篇文章主要給大家介紹了關(guān)于如何利用vue+element?ui實(shí)現(xiàn)好看的登錄界面的相關(guān)資料,需要的朋友可以參考下2022-05-05