日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Vue 如何使用props、emit實現自定義雙向綁定的實現

瀏覽:106日期:2023-01-15 15:09:21

下面我將使用Vue自帶的屬性實現簡單的雙向綁定。

下面的例子就是利用了父組件傳給子組件(在子組件定義props屬性,在父組件的子組件上綁定屬性),子組件傳給父組件(在子組件使用$emit()屬性定義一個觸發方法,在父組件上的子組件監聽這個事件)。

import Vue from ’vueEsm’ var Com = { name:’Com’, props:[’val’], template:`<input type=’text’ @input=’handleInput’/>`, methods: { handleInput(e){ this.$emit('input',e.target.value); } },}new Vue({ el:’#app’, data() { return { value:’’ } }, components:{ Com }, template:` <div> <Com @input=’post’ :val=’value’></Com> </div> `, methods:{ post(data){ this.value=data; } } })

上面這個例子,在input標簽上每次輸入時觸發原生事件input,在這個事件上綁定了一個handleInput方法,事件每次觸發都會執行方法里的$emit屬性。該屬性里面第一個參數可以定義一個事件名,第二個參數可以傳一個參數。這里我們把每次輸入的值e.target.value傳進去。在父組件的子組件上監聽這個事件,定義一個post方法,方法的參數就是傳入的數據。然后我們在父組件的data屬性里定義一個存儲值的變量value。將剛才傳入的參數賦給這個變量value。最后在父組件的子組件上綁定一個自定義屬性,比如val。將value傳給val。在子組件定義一個props屬性接受這個val。

這個例子對于理解父組件與子組件傳值特別重要。

下方舉例說明了我的一個自定義mySelect的實現過程:

<template> <div class='select'> <div @click='collapse=!collapse'> <span v-if='currentValue'>{{currentLabel||currentValue}}</span> <span v-else class='placeholder'>{{placeholder}}</span> <span :class='collapse?’arrow-down’:’arrow-up’'></span> </div> <div v-show='!collapse'> <div v-for='item in data' :key='item.id' @click='chooseItem(item)'>{{item[itemLabel?itemLabel:’name’]}}</div> </div> </div></template><script> export default { name: 'mySelect', props: [ ’value’, ’placeholder’, ’data’, ’itemLabel’, ’itemValue’ ], data() { return { collapse: true, currentValue: ’’, currentLabel: ’’, } }, watch: { value: { immediate: true, handler(value) { this.currentValue = value; this.$emit(’input’, value); this.data.forEach(item => { if (item[this.itemValue ? this.itemValue : ’id’] == value) { return this.currentLabel = item[this.itemLabel ? this.itemLabel : ’name’]; } }); } }, data:{ immediate: true, handler(arr) { if(this.value||!this.currentLabel){ arr.forEach(item=>{ if(item[this.itemValue ? this.itemValue : ’id’] == this.value){this.currentLabel = item[this.itemLabel ? this.itemLabel : ’name’];return; } }) } } } }, methods: { chooseItem(item) { if (this.currentValue !== item[this.itemValue ? this.itemValue : ’id’]) { this.$emit(’change’,item[this.itemValue ? this.itemValue : ’id’]); } this.currentValue = item[this.itemValue ? this.itemValue : ’id’]; this.currentLabel = item[this.itemLabel ? this.itemLabel : ’name’]; this.$emit(’input’, this.currentValue); this.collapse = true; } } }</script><style lang='scss' scoped> .select { position: relative; .input { width: 100%; height: 30px; line-height: 30px; background-color: #fff; border: 1px solid #02b4fe; border-radius: 0 3px 3px 0; padding-left: 10px; color: #666; position: relative; .placeholder { color: #aaa; } } .arrow-down { width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 8px solid #02b4fe; position: absolute; right: 5px; top: 10px; } .arrow-up { width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-bottom: 8px solid #02b4fe; position: absolute; right: 5px; top: 10px; } .option-list { max-height: 200px; overflow-y: scroll; position: absolute; top: 2rem; left: 0; z-index: 5; width: 100%; padding: 0 5px; font-size: 10px; color: #aaa; background-color: #fff; text-align: left; box-shadow: 0 0 5px rgba(0, 0, 0, .1); border: 1px solid rgb(79, 192, 232); .option-item { text-align: center; line-height: 1.5rem; } } }</style>

如上所示,當聲明了mySelect組件之后,在項目中實際使用時,就可以如下所示直接使用:

<template> <mySelect v-model='testValue' placeholder='請選擇' :data='testArr' item-label='id' item-value='name'></mySelect></template><script> import mySelect from ’./mySelect’ export default{ components:{ mySelect }, data(){ return { testValue:’’, testArr:[] } }, mounted(){ //預置select的下拉選擇基礎數據,數據為對象數組,包含id和name屬性 }}</script>

以上就是一個簡單的自定義雙向綁定組件的實現,包括簡單的使用過程。在vue中的自定義組件,關于props的聲明時,還是盡量使用官方建議的對象方式,可以聲明屬性的默認值和數據類型。我這邊偷懶了用的是props的字符串數組簡寫方式,但是這樣的話對使用組件時的錯誤調試不利。所以,盡量不要學我偷懶噢,親~~~

到此這篇關于Vue 如何使用props、emit實現自定義雙向綁定的實現的文章就介紹到這了,更多相關Vue props、emit實現自定義雙向綁定內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩一区二区三区四区在线观看 | 国产精品亚洲一区二区三区在线观看| 电影亚洲精品噜噜在线观看| 欧美精品中文字幕亚洲专区| 免费人成网站在线观看欧美高清| 中文字幕在线免费观看视频| 欧美精品国产白浆久久久久| 亚洲欧美日韩国产一区二区| 久久人人88| 日韩国产高清在线| 视频在线观看一区二区三区| 亚洲激情五月| 久久一二三区| 久久中文字幕av| 99国产精品久久久久久久成人热 | 国产亚洲精品美女久久 | 亚洲免费成人av在线| 99视频在线精品国自产拍免费观看| 久久精品高清| 欧美午夜精彩| 午夜在线一区二区| 婷婷精品在线| 成人精品亚洲| 欧美日韩国产一区二区三区不卡| 午夜欧美理论片| 亚洲精品黄色| 91青青国产在线观看精品| 精品一区电影| 欧美日中文字幕| 日韩国产在线一| 亚洲在线观看| 国产精品久久久久久久久免费高清 | 国产欧美日韩| 国产精品久久久久久久久久久久久久久 | 久久精品中文| 国产日韩1区| 日韩欧美一区二区三区免费观看| 国产在线成人| 97久久精品| 国产亚洲高清在线观看| 国产一区二区亚洲| 国产精品老牛| 国产综合婷婷| 中文一区一区三区免费在线观| 麻豆精品99| 午夜国产欧美理论在线播放 | 国产精品99在线观看| 中文字幕日韩亚洲| 久久uomeier| 日本成人手机在线| 国内亚洲精品| 亚洲性图久久| 精品网站aaa| 91精品丝袜国产高跟在线| 欧美 日韩 国产一区二区在线视频| 日韩一区二区免费看| 综合日韩av| 老司机精品视频在线播放| 蜜臀va亚洲va欧美va天堂| 午夜久久tv| 久久久久免费| 精品国产一区二区三区性色av| 日韩欧美中文字幕一区二区三区| 日韩一区欧美二区| 国产suv精品一区二区四区视频 | 国产精品久久久久9999高清| 日韩在线一二三区| 亚洲午夜久久久久久尤物| 99国产精品| 老司机久久99久久精品播放免费| 九九在线精品| 欧美精品一区二区久久| 精品网站999| 风间由美中文字幕在线看视频国产欧美| 婷婷亚洲成人| 日本一不卡视频| 国产调教精品| 黑人精品一区| 久久男人av资源站| 精品丝袜在线| 亚洲欧美日本国产专区一区| 亚洲精品欧美| 日韩精品久久理论片| 久久国产麻豆精品| 精品淫伦v久久水蜜桃| 日韩精品不卡一区二区| 波多视频一区| 亚洲欧美日本日韩| 国产精品白浆| 欧美中文一区二区| 爽好久久久欧美精品| 69堂免费精品视频在线播放| 精品色999| 99国产精品99久久久久久粉嫩| 91成人精品| 国产美女亚洲精品7777| 久久久久国产精品一区三寸| 日韩欧美一区二区三区在线观看 | 亚洲乱码久久| 日本成人一区二区| 伊人久久av| 国产欧美高清| 国产99精品| 一区在线观看| av在线最新| 国产精品三级| 亚洲一区二区免费在线观看| 国产毛片精品久久| 啪啪国产精品| 奇米狠狠一区二区三区| 亚洲激情婷婷| 精品国产乱码久久久| 999久久久91| 国产精品国产一区| 国产精品视频3p| 中文久久精品| 国精品产品一区| 国产私拍福利精品视频二区| 久久国产精品久久久久久电车 | 美女久久一区| 欧美成人a交片免费看| 午夜在线精品| 中文日韩欧美| 亚洲性视频h| 国产一区日韩一区| 日本va欧美va瓶| 91精品99| 亚洲一区久久| 日韩专区在线视频| 亚洲欧美日韩国产综合精品二区| 日韩欧美看国产| 国产精品蜜芽在线观看| 精品淫伦v久久水蜜桃| 日韩欧美精品一区| 久久狠狠久久| 日韩中文字幕无砖| 视频一区日韩| 久久精品99国产国产精| 日韩午夜一区| 国产亚洲精品久久久久婷婷瑜伽| 欧美日韩高清| 亚洲网站视频| 日韩欧美精品综合| 在线视频观看日韩| 国模 一区 二区 三区| 好看不卡的中文字幕| 久久国产电影| 六月婷婷一区| 日韩欧美激情| 国产精品永久| 国产一区二区三区久久久久久久久| 清纯唯美亚洲综合一区| 国产精品亲子伦av一区二区三区| 另类小说一区二区三区| 美女视频网站久久| 久久精品99久久久| 日韩免费一区| 日韩专区欧美专区| 日本精品久久| 色偷偷色偷偷色偷偷在线视频| 亚洲高清不卡| 日韩高清在线一区| 色偷偷偷在线视频播放| 91精品久久久久久久久久不卡| 日韩影院精彩在线| 欧美激情一区| 伊人久久亚洲美女图片| 国产精品免费99久久久| 精品视频97| 婷婷综合国产| 成人日韩在线| 国产伦理久久久久久妇女| 激情五月综合| 国产精品亚洲片在线播放| 另类中文字幕国产精品| 亚洲69av| 亚洲精品一二三区区别| 国产精品v亚洲精品v日韩精品| 天堂资源在线亚洲| 一二三区精品| 国产精品亚洲片在线播放| 欧美日韩国产欧| 一区二区精品伦理...| 日韩美女精品| 亚洲欧洲另类| 国产传媒在线观看| 精品三级av在线导航| 欧美日韩一区二区国产| 亚洲欧洲专区| 午夜欧美精品| 国产精品99一区二区| 国产精品久久久久久久久妇女| 日韩av影院| 亚洲无线一线二线三线区别av| 麻豆精品在线观看| 男女性色大片免费观看一区二区| 欧美精品一区二区久久| 国产精品久久久久久久久妇女| 里番精品3d一二三区| 国产乱码精品一区二区亚洲|