首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

innerHTML导致事件失效bug

在用innnerHTML形式添加元素之后,事件绑定失效,如下 document.body.innerHTML += 'xxx'; 其实就是: document.body.innerHTML = (document.body.innerHTML...+ 'xxx'); 把原本元素摧毁之后重建一个加上'xxx'新元素,所以旧元素handler也被重置(又或着是说丢失)了!...body元素内容变了,DOM元素结构已经变了 那么之前通过 var oBtn=document.getElementById('btn'); 获取oBtn在当前DOM树中已经不存在了,这点我们可以通过在...document.body.innerHTML+=str; var _oBtn_=document.getElementById('btn'); console.log(oBtn.onclick); //之前绑定事件还存在...虽然在DOM树中不存在了,但是对象还在函数体中,并没有被GC掉,所以oBtn.onclick还能正常运行 但点击行为触发是基于DOM树结构中元素,故浏览器中事件也称为DOM事件 既然元素都不在

1.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    js事件

    (); 7.JS值类型:String,Number,Boolean,Null,Object,Function 8.JS字符型转换成数值型:parseInt(),parseFloat() 9.JS...中数字转换成字符型:(""+变量)10.JS取字符串长度是:(length) 11.JS字符与字符相连接使用+号. 12.JS比较操作符有:==等于,!...=不等于,>,>=,<.<= 13.JS中声明变量使用:var来进行声明 14.JS判断语句结构:if(condition){}else{} 15.JS循环结构:for([initial expression...HTML: 51.当超链和ONCLICK事件都有时,则老版本浏览器转向a.html,否则转向b.html.例:<a href="a.html" onclick......多重继续. 73.JSself指的是当前窗口 74.JS中状态栏显示内容:window.status="内容" 75.JStop指的是框架集中最顶层框架 76.JS中关闭当前窗口:

    10.8K110

    js动画事件_JavaScript事件

    js之动画事件 首先,动画事件主要包括以下三个animationstart,animationiteration和animationend事件,下面做简单分别介绍。...animation主要有6个属性,分别来设置动画呈现出来哦效果,这个在我另一篇文章中有介绍,我这边简单展示一下。...animation:name duration timing-function delay iteration-count direction; 分别是:动画名称 动画持续事件 动画运行速度曲线 动画开始时运行时间...下面一段代码讲述是采用监听动画开始,动画再次播放和动画结束做出相应改变,这里用到addEventListener监听动画开始、动画持续播放、动画结束播放。 <!...如发现本站有涉嫌侵权/违法违规内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    18.4K10

    Js 事件委托(事件代理)

    一、概述 事件委托,又叫事件代理。事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型所有事件。 例子:有三个同事预计会在周一收到快递。...这里其实还有2层意思: 第一,现在委托前台同事是可以代为签收,即程序中现有的dom节点是有事件; 第二,新员工也是可以被前台MM代为签收,即程序中新添加dom节点也是有事件。...二、为什么是使用事件委托 一般来说,dom需要有事件处理程序,我们都会直接给它设事件处理程序就好了,那如果是很多dom需要添加事件处理呢?...,这就是为什么性能优化主要思想之一就是减少DOM操作原因;如果要用事件委托,就会将所有的操作放到js程序里面,与dom操作就只需要交互一次,这样就能大大减少与dom交互次数,提高性能; 每个函数都是一个对象...三、事件委托原理 事件委托利用事件冒泡原理,将事件绑定到父级元素上,当点击子元素时,通过事件冒泡将事件传递到父级元素。  四、总结: 那什么样事件可以用事件委托,什么样事件不可以用呢?

    11.4K30

    js事件(event)

    什么是事件: 我们可以简单事件理解为浏览器感知系统。...,相当于文档中鼠标的坐标; target事件源;事件概念:事件最终发生在页面的那个元素上; 事件源和事件传播是息息相关 事件传播包括:冒泡和捕获;事件传播是浏览器在处理事件行为机制,冒泡阶段或者捕获阶段...;当你在一个form表单里点击提交按钮时网页会产生一个行为病刷新网页,当你网页上滚动鼠标滚轮时候,页面的滚动条会滚动等等;这些都叫事件默认行为,如果想把这些默认行为取消了,相应js代码如下: a.onclick...{ //在这里可以加一些代码,实现自定义右键菜单; return false //系统自带右键菜单就失效了 } Form.onsubmit = function(){return false;}//...事件委托: 事件委托是利用事件传播机制,通过判断事件源来实现,是一种高性能事件处理方式。对事件委托好处和概念详见《高程3》第402页; 我们通过一个简单示例来看看事件好处。

    6.9K30

    js事件循环

    首先,我们来解释下事件循环是个什么东西: 就我们所知,浏览器js是单线程,也就是说,在同一时刻,最多也只有一个代码段在执行,可是浏览器又能很好处理异步请求,那么到底是为什么呢?...我们先来看一张图(这张图来自于http://www.zcfy.cc/article/node-js-at-scale-understanding-the-node-js-event-loop-risingstack...从上图我们可以看出,js主线程它是有一个执行栈,所有的js代码都会在执行栈里运行。...其实(正如上图所示),js是有两个任务队列,一个叫做Macrotask Queue(Task Queue),一个叫做Microtask Queue 前者主要是进行一些比较大型工作,常见有setTimeout...原因:因为一开始js主线程中跑任务就是macrotask任务,而根据事件循环流程,一次事件循环只会执行一个macrotask任务,因此,执行完主线程代码后,它就去从microtask队列里取队首任务来执行

    18.8K41

    js 事件笔记

    一、事件简述 1、事件概念 在Web中, 事件在浏览器窗口中被触发,执行事先绑定事件处理器(也就是事件触发时会运行代码块),对事件做出响应。...2、常见事件 事件是某个行为或者触发,比如点击、鼠标移动、提交表单,滚动菜单等等 二、事件流 1、事件作用 事件流描述是从页面中接收事件顺序,比如有两个嵌套div,点击了内层div,这时候是内层...DOCTYPE html> JS Bin .box1{ border:...1、事件对象来源 在触发DOM上某个事件时候会产生一个事件对象event,这个对象包含着所有与事件有关信息,包括产生事件元素、事件类型等相关信息。...2、event常见属性 event对象包含与创建它特定事件有关属性和方法,触发事件类型不同,可用属性和方法也不同,但是所有事件都会包含 ?

    11K21

    js事件大全

    一般事件 事件 浏览器支持 描述 onClick IE3|N2|O3 鼠标点击事件,多用在某个对象控制范围内鼠标点击 onDblClick IE4|N4|O 鼠标双击事件 onMouseDown...onMouseMove IE4|N4|O 鼠标移动时触发事件 onMouseOut IE4|N3|O3 当鼠标离开某对象范围时触发事件 onKeyPress IE4|N4|O 当键盘上某个键被按下并且释放时触发事件...onMove IE|N4|O 浏览器窗口被移动时触发事件 onResize IE4|N4|O 当浏览器窗口大小被改变时触发事件 onScroll IE4|N|O 浏览器滚动条位置发生变化时触发事件...onStop IE5|N|O 浏览器停止按钮被按下时触发事件或者正在下载文件被中断 onUnload IE3|N2|O3 当前页面将被改变时触发事件 表单相关事件 事件 浏览器支持 描述...元素完成需要显示内容后触发事件 onStart IE4|N|O 当Marquee元素开始显示内容时触发事件 编辑事件 事件 浏览器支持 描述 onBeforeCopy IE5|N|O 当页面当前被选择内容将要复制到浏览者系统剪贴板前触发事件

    3.8K10

    JS 事件循环

    ,脚本执行,事件处理等 其包含线程有:GUI 渲染线程(负责渲染页面,解析 HTML,CSS 构成 DOM 树)、JS 引擎线程、事件触发线程、定时器触发线程、http 请求线程等主要线程 关于执行中线程...: 主线程:也就是 js 引擎执行线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...工作线程:也称幕后线程,这个线程可能存在于浏览器或js引擎内,与主线程是分开,处理文件读取、网络请求等异步事件。...宏任务主要包含:script( 整体代码)、setTimeout、setInterval、I/O、UI 交互事件、setImmediate(Node.js 环境) 微任务主要包含:Promise、MutaionObserver...、process.nextTick(Node.js 环境) setTimeout/Promise 等API便是任务源,而进入任务队列是由他们指定具体执行任务。

    15.4K10

    js --- 事件

    1.事件流   事件发生时会在元素节点与根节点之间按照特定顺序传播,路径所经过所有节点都会收到该事件,这个传播过程即DOM事件流。...2.两种事件流模型   1.冒泡型事件流:事件传播是从最特定事件目标到最不特定事件目标。即从DOM树叶子到根   2.捕获型事件流:事件传播是从最不特定事件目标到最特定事件目标。...即从DOM树根到叶子 3.绑定事件方法   1.普通浏览器 绑定事件:addEventListener(type,name,bool);     删除事件:removeEventListener...()   2.ie 低版本 绑定事件:attachEvent()     删除事件:detachEvent() 4.参数说明 type 事件类型 例如:click load   name...事件执行函数   bool true 为事件捕获 && false 为事件冒泡 5.阻止事件冒泡和 事件捕获 1.阻止事件冒泡 不 阻止默认行为     event.stopPropagation

    7.6K30

    js事件基础

    所以存在兼容性问题。 事件冒泡 事件冒泡就是当事件对象有父子级关系时,当执行子级事件后,父级事件也会因为事件冒泡,也会执行,因此,大多数时候,事件冒泡需要消除。...在火狐或者谷歌浏览器下,使用事件方法是将函数中传进来e; 而在IE浏览器下,使用事件不需要传进e,直接使用event。...所以为了避免事件兼容性问题 var oEvent = e || event; 一般使用这样方法来消除浏览器对事件兼容 鼠标点击事件 鼠标的位置 oevent.clientX:返回鼠标的横坐标的位置...^ _ ^ ) 小案例——自定义右菜单 1.实现点击鼠标右键弹出自己菜单 2.实现点击空白时,菜单消失 3.实现点击菜单时,菜单不会消失(事件冒泡) <!...:animate.js 代码如下 <!

    3.2K10

    js事件委托

    概念 事件委托也叫事件代理,事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型所有事件。...动态绑定: 新生dom节点如果用原来方式是无法绑定事件,用委托方式这方面可以轻松实现,保证父元素存在即可。...原理 利用事件冒泡,而冒泡指就是事件从向上传递事件,如果事件有相应函数绑定就会执行其绑定函数。...举例:ul下li元素有绑定事件,我们通过ul绑定委托之后,委托源码部分会在其执行函数内针对事件源进行筛选判定是否符合筛选条件(是否是li),然后针对获取属性或者内容,进行相关操作。...从这里可以看到没有直接针对特定元素绑定事件,而是对事件源进行匹配,所以不存在新生元素无事件问题。

    3.3K31

    JS事件

    (子节点):删除子节点 使用innerHTML也可以完成DOM增删改操作 阻止a标签默认行为常用三种方式 a标签索引问题 JS修改元素样式 读取元素内联样式 获取当前元素显示样式---只读...JS修改元素样式一些思考 JSON JSON字符串转化为JS对象 JS对象转换为JSON字符串 eval函数 ---- window.onload:事件 浏览器加载一个页面时,是按照自上而下顺序加载...,不然鼠标移动出了div,事件失效了 document.onmousemove=function(event) { //兼容性写法 event=event||window.event...,从而产生速度越来越快情形 按钮点击开启一个定时器,因此需要在开启定时器前关闭上一次开启定时器 ---- 延时调用 ---- JS修改元素样式一些思考 追加属性记得加一个空格 -...--- JSON JSON字符串转化为JS对象 JS对象转换为JSON字符串 ---- eval函数

    12.6K10
    领券