久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - Vue 自定義控件v-model雙向綁定

瀏覽:111日期:2023-02-23 13:42:25

問題描述

<currency-input v-model='price'></currency-input>Vue.component(’currency-input’, { template: ’ <span> $ <inputref='input'v-bind:value='value'v-on:input='updateValue($event.target.value)' > </span> ’, props: [’value’], methods: { // 不是直接更新值,而是使用此方法來對輸入值進行格式化和位數(shù)限制 updateValue: function (value) { var formattedValue = value// 刪除兩側(cè)的空格符.trim()// 保留 2 小數(shù)位.slice(0, value.indexOf(’.’) + 3) // 如果值不統(tǒng)一,手動覆蓋以保持一致 if (formattedValue !== value) {this.$refs.input.value = formattedValue } // 通過 input 事件發(fā)出數(shù)值 this.$emit(’input’, Number(formattedValue)) } }})vue入門指導里的,請問input事件是什么時候觸發(fā)的,一旦觸發(fā),`this.$emit(’input’, Number(formattedValue))`不會導致input事件不停被觸發(fā),updateValue循環(huán)被調(diào)用嗎?

問題解答

回答1:

oninput事件是IE之外的大多數(shù)瀏覽器支持的事件,在value改變時觸發(fā),實時的,即每增加或刪除一個字符就會觸發(fā),然而通過js改變value時,卻不會觸發(fā);

所以input是在input里的內(nèi)容發(fā)生變化時觸發(fā)的,至于這里的this.$emit(’input’, Number(formattedValue)),事實上這里是發(fā)送自定義事件’input’,他是用于父子組件之間的通信的,也就是說這里emit的事件并不會被組件自己捕捉,也就是不會觸發(fā)這里的updateValue,你在的<currency-input v-model='price'></currency-input>這里增加一下input的監(jiān)聽,emit觸發(fā)的是這里的,所以不會發(fā)送你說的循環(huán)調(diào)用的情況。

標簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 宝清县| 永春县| 杭锦旗| 理塘县| 长海县| 绥滨县| 平山县| 中西区| 门头沟区| 湟中县| 西昌市| 苏尼特右旗| 霞浦县| 泰来县| 荔波县| 佳木斯市| 建瓯市| 合江县| 新巴尔虎左旗| 马关县| 崇礼县| 广元市| 喀喇沁旗| 镇远县| 油尖旺区| 新干县| 乾安县| 厦门市| 徐汇区| 同江市| 金坛市| 扶余县| 甘泉县| 兴海县| 武宣县| 宁乡县| 新巴尔虎右旗| 安图县| 南木林县| 威信县| 大洼县|