javascript - Vue 自定义控件v-model双向绑定
问题描述
<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: { // 不是直接更新值,而是使用此方法来对输入值进行格式化和位数限制 updateValue: function (value) { var formattedValue = value// 删除两侧的空格符.trim()// 保留 2 小数位.slice(0, value.indexOf(’.’) + 3) // 如果值不统一,手动覆盖以保持一致 if (formattedValue !== value) {this.$refs.input.value = formattedValue } // 通过 input 事件发出数值 this.$emit(’input’, Number(formattedValue)) } }})vue入门指导里的,请问input事件是什么时候触发的,一旦触发,`this.$emit(’input’, Number(formattedValue))`不会导致input事件不停被触发,updateValue循环被调用吗?
问题解答
回答1:oninput事件是IE之外的大多数浏览器支持的事件,在value改变时触发,实时的,即每增加或删除一个字符就会触发,然而通过js改变value时,却不会触发;
所以input是在input里的内容发生变化时触发的,至于这里的this.$emit(’input’, Number(formattedValue)),事实上这里是发送自定义事件’input’,他是用于父子组件之间的通信的,也就是说这里emit的事件并不会被组件自己捕捉,也就是不会触发这里的updateValue,你在的<currency-input v-model='price'></currency-input>这里增加一下input的监听,emit触发的是这里的,所以不会发送你说的循环调用的情况。
相关文章:
1. node.js - webpack --watch以后报错env: node: No such file or directory2. 静态资源文件引入无效3. node.js - 在node中,一个加密操作用时69ms,是否可以接受?4. javascript - 表单提交后,后台直接返回页面,应该如何处理?5. javascript - htaccess rewrite 的问题6. javascript - UI样式计算过多导致浏览器加载过慢,IE尤其严重,求前辈指导7. css3:flex排版问题8. javascript - <div onclick="fun()"></div>这种fun函数只有写成全局函数才有效吗?9. javascript - jQuery 获取表格所有数据10. javascript - webpack 多入口文件生成HTML文件;

网公网安备