首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS原生数据绑定原理

用过vue的人都知道,vue有一个特别好用的数据绑定,只要绑定了,你只要改变了这个数据,页面也会跟着渲染。其实原生JS也是可以做到的,vue其实就是用了原生的原理。...hello", configurable:false }); console.log(obj.val); //输出hello 现在说说最重要的getter和setter方法,数据绑定的主要方法...obj.hello = e.target.value; console.log(obj.hello) }; obj.hello = 999; 当我们监听input的键盘事件的时候...这时候估计很多人会觉得都是监听,那还不如直接写在input的监听事件里面,其实不是的,只要你调用了obj.hello,页面的值就会变化。...就像obj.hello = 999;那么页面的值就会是999;感兴趣的可以复制代码的方法,一个一个方法调用,就很容易明白原生JS的双向绑定

1.8K30

js绑定事件代理的坑

js通过事件代理的方式绑定跳转事件,我这里的逻辑是把click事件绑定在最外层container上面,如果e.target包含我已经写好的class,则执行跳转逻辑。...但是这种方式好像只能是在点击的元素的上面,也就是最内层的元素上面有相应的class才能跳转,在外层加同样的class不生效,说明是我对于事件代理的理解不够深刻,其实事件代理的作用就是为了把目标元素的事件绑定在外层做代理...,又想要外层元素含有class时执行点击事件,修改优化如下: document.querySelector('#container').addEventListener('click', function...(e) { console.log(e.currentTarget) //获得当前绑定监听事件的元素, container console.log(e.target)/...即点击的目标元素必须是点击时真正的目标元素,而不是外面一层; currentTarget绑定相应想要点击的class的时候必须是做代理的即做事件监听的元素。

4.9K20

input获取焦点 原生js_原生js的input事件

1.onfocus 当input 获取到焦点时触发 2.onblur 当input失去焦点时触发,注意:这个事件触发的前提是已经获取了焦点再失去焦点的时候才会触发该事件,用于判断标签为空。...4.onkeydown 按下按键时的事件触发, 5.onkeyup 当按键抬起的时候触发的事件,在该事件触发之前一定触发了onkeydown事件–相当于一个按键,两个事件,没怎么用过 6.onclick...主要是用于 input type=button,input作为一个按钮使用时的鼠标点击事件 7.onselect 当input里的内容文本被选中后执行,只要选择了就会触发,不是全部选中 8.oninput...当input的value值发生变化时就会触发,(与onchange的区别是不用等到失去焦点就可以触发了) 使用方法: 以上事件可以直接放到input的属性里,例如: 1 , 可以通过js给input...dom元素添加相应的事件, 2 document.getElementByTagName(‘input’).onfocus = function(); 3 事件监听。

25.3K60

小程序实践(五):for循环绑定item的点击事件

对应的数据源(js文件中): ? 写一个点击监听: ? 效果: ?...-------------------------------------- 解决方法: 给有点击事件的组件添加一个 data-any  属性 any可以是任意数据类型。...然后修改点击事件: ?  发现可以用此方法去除点击的item对应的数据对象,以及该对象中某个属性值     控制台打印信息: ?  这样就可以获取到列表展示数据中某一个item对应的数据了。...小程序实践(一):主页tab选项实现 小程序实践(二):swiper组件实现轮播图效果 小程序实践(三):九宫格实现及item跳转 小程序实践(四):动态控制组件的显示/隐藏 小程序实践(五):for循环绑定...item的点击事件

3.3K10

原生js实现vue的数据双向绑定

写在前面 很多面试官在面试的时候为了显示自己很牛,喜欢问面试者,你会不会使用原生js实现vue的双向绑定啊,每次我遇到这种面试官我都想揍他一顿,不是说这个问题问得不好,我就想问问,我会或者不会影响我使用...如果真的是使用原生的话,需要这种功能吗?如果使用vue的话,需要知道吗?但是很多面试官还是会问,所以这里我还是给大家写一下,其实没有想象的那么的难!...简单的分析一波 所谓的双向绑定就是这边输入数据的时候,另一个dom节点可以时刻监听到这个数据的变化,并且做出相应的操作,最简单的操作就是输入什么就显示什么,这个是怎么实现的呢?

1.7K20

【Node.JS事件绑定与触发

往期文章 【Node.JS】写入文件内容 【Node.JS】读取文件内容 目录 简介 绑定事件 on() addListener()  once() 监听事件emit()  传参  删除事件 removeListener...()  removeAllListeners() ---- 简介 node.js事件是使用events模块,通过实例化它里面的EventEmitter类,来绑定和监听事件。...绑定事件 on() const eve = require("events"); //导入模块 var event = new eve.EventEmitter(); //进行实例化声明 event.on...('namea', function () { console.log("坚毅的小解同志"); }) 查看绑定事件 const eve = require("events"); //导入模块...event.emit('namea', '小解');  once() once 只会绑定一次性的触发事件,触发一次后就会解除绑定

11K40

JS动态加载数据绑定事件--delegate() 方法

JS动态加载数据绑定事件-委托delegate() 方法 ---- W3C规范定义 定义和用法 delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数...---- JavaScript动态加载的数据,同时给他加载绑定事件,我选用Jquwey中的 delegate() 方法 我的理解,delegate()方法属于异步式加载绑定,dom元素加载未完成之前,可以委托给...delegate() 方法来实现的绑定操作。...delegate(".top-nav-left","click",function() { window.history.back(); }); }); ---- 第一个参数为 要点击的标签属性...第二个参数为 要绑定事件 详情,请翻阅delegate() 方法 ---- 效果如图的返回按钮:

7.8K30

使用原生JS实现鼠标点击爱心效果 !!!

使用原生JS,实现鼠标点击爱心效果 !!! 引言: 在很多时候我们都需要实现鼠标点击出现图案或者文字这样的效果,对于用户而言,这样的体验是很极致的。其实实现起来也很简单,下面一起来学习一下吧。...文本上升效果 let i = 0 setInterval(() => { _this.style.top = this.y - 20 - i + 'px' i++ }, 10); 由于原生...js中直接操作动画帧的样式比较复杂,所以采用定时器实现相同的功能,将标签的top值逐渐减小,这样标签就会实现上升的效果 4....文字逐渐变淡效果 @keyframes remove { 100% { opacity: 0; } } 逐渐变淡的效果是通过css3动画来实现的很简单,动画是通过js来给元素绑定的...鼠标点击实例化标签,并在点击位置生成 body.addEventListener('click', function (e) { let x = e.pageX; let y = e.pageY

4.8K30
领券