javascript - vue如何侦听change事件实现双向绑定的?
问题描述
我们用原生的事件侦听一个input输入框变化时绑定这么一个事件,这个回调函数执行的条件是输入框blur之后
el.addEventListener(’change’, function(e){ console.log(e.target.value);})
但是 Vue.js 和 React.js这类框架对于绑定change事件的input并不需要blur才会触发回调函数,而是每一次实时输入就会触发回调,就像IE的onpropertychange事件一样。
这个是如何做到的?
问题解答
回答1:但是 Vue.js 和 React.js这类框架对于绑定change事件的input并不需要blur才会触发回调函数,而是每一次实时输入就会触发回调,就像IE的onpropertychange事件一样。 这个是如何做到的?
vue中的输入框默认监听的是input事件,所以输入就会触发回调。通过下面这种方式可以改成change中触发。
<input v-model.lazy='msg' >回答2:
其实框架层面底层还是有对DOM事件的监听,比如你说的input输入框监听了input事件,只是Vue框架不需要在input事件中去写操作(虽然可以写),自动将DOM变动转换成了数据模型的变动。
最近在gitchat上做一场分享,可以看看这里。JavaScript 进阶之深入理解数据双向绑定
回答3:根据你的问题你是想了解vue的双向绑定实现原理,这类文章SF还是有许多的。@邓木琴居然被盗用了 这篇文章可以参考下链接描述
相关文章:
1. html5 - 有可以一次性把所有 css外部样式转为html标签内style=" "的方法吗?2. javascript - 原生canvas中如何获取到触摸事件的canvas内坐标?3. javascript - vscode alt+shift+f 格式化js代码,通不过eslint的代码风格检查怎么办。。。4. javascript - 求解答:实例对象调用constructor,此时constructor内的this的指向?5. javascript - [js]为什么画布里不出现图片呢?在线等6. html - vue项目中用到了elementUI问题7. javascript - 如何将一个div始终固定在某个位置;无论屏幕和分辨率怎么变化;div位置始终不变8. java - 如何写一个intellij-idea插件,实现编译时修改源代码的目的9. javascript - 有什么比较好的网页版shell前端组件?10. java 中Long 类型如何转换成Double?
