目前已有很多私有前缀可以不写了,但为了兼容老版本的浏览器,可以仍沿用私有前缀和标准方法,逐渐过渡。...,当input或者textarea设置了该属性后,该值的内容将作为灰字提示显示在文本框中,当文本框获得焦点或输入内容时,提示文字消失。...对于其兼容性首先需要判断input是否支持placeholder,然后在不支持的情况下可以通过input的onfocus与onblur事件监听来实现placeholder效果。 IE9之前的浏览器阻止默认行为需要使用window.event.returnValue = false。直接在事件处理函数中return false也能阻止默认行为,只在DOM0级模型中有效。...此外,在jQuery中使用return false会同时阻止默认行为与事件传播,通常也会封装一个方法来实现默认行为的阻止。
" value="******" onBlur="if(this.value=="") this.value="******";" onFocus="if(this.value=="******") this.value...="";"> jquery实现方法 对于元素的焦点事件,我们可以使用jQuery的焦点函数focus(),blur()。...focus():得到焦点时使用,和javascript中的onfocus使用方法相同。...如: $("p").focus(); 或$("p").focus(fn) blur():失去焦点时使用,和onblur一样。... 这里label覆盖在文本框上,可以更好的控制样式 <input type="submit" value="搜索
和onactivate 事件。...onbeforedeactivate事件触发条件:焦点从当前活动对象转移到同一个document的另一个对象时触发,它和onblur的区别在于, onblur先触发relatedElement的onfocus...,然后在触发自身的onblur。...而对于onbeforedeactivate是先触发该事件,如果返回true,则 继续触发另一个元素的onfocus,如果返回false,则不执行。 ...4,对于ie,在执行execCommand之前先让contentWindow获取焦点irf.contentWindow.focus()
文本框失去焦点事件、获得焦点事件 onBlur:当失去输入焦点后产生该事件 onFocus:当输入获得焦点后,产生该文件 Onchange:当文字值改变时,产生该事件 Onselect:当文字加亮后,产生该文件...onpropertychange 当属性改变发生该事件 无论粘贴 keyup onchange等,最为敏感 先来看javascript的直接写在了input上 jquery实现方法 对于元素的焦点事件...focus():得到焦点时使用,和javascript中的onfocus使用方法相同。...这里label覆盖在文本框上,可以更好的控制样式 jquery代码 $(function() { $(‘#searchKey’).focus(function() { $(‘#lbSearch’)....其中placeholder就是其中一个,它可以同时完成文本框获得焦点和失去焦点。必须保证input的value值为空, placeholder的内容就是我们在页面上看到的内容。
一、案例需求 实现如下效果 , 默认状态下 , 表单显示灰色提示字体 , 点击表单输入内容是黑色字体的 ; 二、案例核心要点 1、获取焦点事件 - onfocus 事件 在 JavaScript 中 ,...当 DOM 元素 获得焦点时 , 该 DOM 元素上绑定的 onfocus 事件被触发 ; 绑定该 onfocus 事件的元素 一般都是 input 表单元素 ; 如 : 当 用户 点击输入框 或 通过键盘切换到输入框时..., 该事件会被触发 ; 绑定 onfocus 事件的方法 : 设置 onfocus 属性 : 可以 通过 DOM 操作 , 给元素添加 onfocus 属性 , 来指定当焦点集中在元素上时要执行的JavaScript...元素上绑定的 onblur 事件被触发 ; 如 : 用户从 输入框 移动到 页面的其他部分 或 按下 Tab 键 移动 焦点时 , 该事件会被触发 ; 绑定 onblur 事件的方法 : 设置 onblur...属性 : 可以通过 DOM 操作 , 给元素添加 onblur 属性 , 来指定当焦点集中在元素上时要执行的JavaScript代码 ; // 行内设置 : 使用 onblur 属性 <input type
1.为对象添加事件的2种方式 ①:在HTML元素中添加对象的事件 事件 <meta http-equiv="content-type" content="text...、字体变色 Mouseout:鼠标从元素上,移出元素范围,和mouseover一起使用 3.鼠标点击事件(左键相关事件) click 鼠标单击事件 dbclick 鼠标双击事件 mousedown/mouseup...,所以在IE中可以直接使用 event对象 火狐没有全局event对象,必须在发生事件时,产生一个event对象 ,传递默认方法 6.form的提交、重置事件 submit/reset onsubmit...、 onsubmit 8.默认事件的阻止和传播阻止 使用场景极为常见,超链接用户点击后,取消了不发生跳转。...()用与阻止事件传播,该方法IE不支持,在IE中 cancelBubble
今天项目上用到了oninput事件,顺便就记录下表单常用事件。...1.onblur:元素失去焦点时触发 Onblur 经常用于表单验证,所有主要浏览器都支持 onblur 事件 onblur="myFunction()"> 支持该事件的...3.onfocus:元素获取焦点时触发 当 input 输入框获取焦点时执行,通常也用于 , , 和,所有主要浏览器都支持 onfocus 事件。...5.onfocusout:元素即将失去焦点时触发 onfocusout 事件在元素即将失去焦点时触发。onfocusout 事件类似于 onblur 事件。主要的区别是 onblur 事件不支持冒泡。...onselect 事件会在文本框中的文本被选中时发生。
然而,对于技术的探索和追求从未停歇。 坚持原创,热衷分享,初心未改,继往开来!...页面样式风格统一布局显示正常,不错乱,使用Div+Css技术。 菜单美观、醒目,二级菜单可正常弹出与跳转。 要有JS特效,如定时切换和手动切换图片轮播。... 三、网站介绍 网站布局方面:计划采用目前主流的、能兼容各大主流浏览器、显示效果稳定的浮动网页布局结构。...(个别网页中运用到js代码)。...'主题';}"> onFocus="if(this.value == '你的留言在这里....') this.value='';" onBlur="if(this.value
大家在做一些浏览器端的聊天功能的时候,或者在一些网站跟在线客服咨询的时候,会看到一些消息通知的提示,常见的有浏览器标签页的闪烁和屏幕右侧的消息通知。本篇博客就在这里简单的介绍一下如何实现这样的功能。...注意:这里需要用到窗口的获取焦点和失去焦点的方法,由于IE和其他Chrome及FireFox的区别,这里需要用到的方法就不一样,具体是: Chrome和FireFox浏览器是window的onfocus..., onblur方法;而IE浏览器则是document的onfocusin, onfocusout方法 下面是代码: 的知识点,就是浏览器窗体获得焦点和失去焦点,Chrome和FireFox浏览器是window的onfocus, onblur方法;而IE浏览器则是document的onfocusin...点击了允许后,则当前域名的网站就被允许在该电脑上出现通知弹框,以谷歌浏览器为例,这时依次点击:设置——高级——内容设置——通知,就可以在允许下面看到刚才点击了允许通知的站点的地址,如图: ?
,’keyCode=’+event.keyCode) } 执行结果: 其实这个过程并没有很意外,唯一感觉不太对劲的是 onchange 事件并不是每次输入框值改变的时候触发的,而是在失去焦点时候,并且在...onblur 之前触发; 2、说说这些事件 onfocus 并没有什么特别的,就是当焦点转移到(点击,tab切换) input 框上边的时候触发; onkeydown 键盘按下的时候触发,但是此时按下的值并没有被输入到...input ,所以,此时的 value 没有值,或者说它的值 只能是之前的旧值 另外,此时可以阻止按键的默认事件; onkeypress 按键在按下之后,并且是按键松开之前触发的; 和 keydown...,抢了onchange 的饭碗; 另外,这东西是新的,IE9以下不支持,需要使用 onpropertychange; 还有这货,仅仅在input, textarea 支持; onkeyup 按键在松开之后触发的...反正我是不敢;在失去焦点之后触发的,明明是 onchange 为什么是在失去焦点后触发的,还偏偏比 onblur 快; 能获取新的到 value,不能拿到 keycode;此时,不可以阻止按键的默认事件
打开一个新页面或者刷新的时候触发 demo查看 相当于onload,加载页面时触发,但是在不同浏览器触发的有所不同 第一次加载页面时,onpageshow在ie浏览器中不触发,其他情况都触发 11.onresize...} 13.onpopstate 当浏览器窗口记录改变时运行的脚本, 14.onredo 当文档执行撤销时触发的事件 二、form事件属性 由html表单内触发的事件,通常使用在form元素中 1.onblur...=myfun()的事件,当input失去焦点的时候产生什么样的效果 demo查看 2.onfocus 元素获得焦点时触发事件,和onblur相反 demo查看 3.onchange 当元素值被改变的时候触发事件...当表单获得输入时可以触发事件 触发发不了脚本 6.onforminput 当表单获得用户输入时触发的事件,无法触发 浏览器不支持 6.oninput 当元素获得用户输入时触发的事件 当输入框输入或者删除时都会触发...按下任意字母数字键时触发,但系统按钮,箭头和功能无法识别 3.onkeyup 松开任何之前按下的键盘时触发 demo查看 四、mouse鼠标事件 利用鼠标触发的事件 1.onclick 鼠标点击元素触发的事件
③ 常用的事件: onload onclick onblur onfocus onmouseover onmouseout BOM ① Borwser Object Model 浏览器对象模型...异步处理 而异步处理指的是我们在浏览网页的同时,通过AJAX向服务器发送请求,发送请求的过程中我们浏览网页的行为并不会收到任何影响,甚至主观上感知不到在向服务器发送请求。...当服务器正常响应请求后,响应信息会直接发送到AJAX中,AJAX可以根据服务器响应的内容做一些操作。 使用AJAX的异步请求基本上完美的解决了同步请求带来的问题。...这里需要稍微注意一下,XMLHttpRequest对象并没有成为标准,但是现在的主流浏览器都支持该对象,而一些如IE6的老版本浏览器中的创建方式有一些区别,但是问题不大。...7.4.4 使用JQuery框架来发送异步请求 JQuery是当前比较主流的 JavaScript 库,封装了很多预定义的对象和实现函数,帮助使用者建立有高难度交互的页面,并且兼容大部分主流的浏览器.
实际上#后面的部分是不会被算在QueryString里面的。所以这里的实际长度只有23。提交者巧妙的使用outerHTML的方式将整个URL都写入到了DOM。但是在这里不得不提的是,浏览器差异问题。...虽然在Internet Explorer(IE8下测试)和Chrome(最新版本)当中,这种方法都可以直接把URL写到DOM中,但是Firefox会将URL编码过的内容写入到DOM中,导致无法完成HTML...所以在实际的操作过程中,如果条件允许的话,可能需要我们调用一些可以对URL进行解码的JS函数,先对URL进行一次解码再写入到DOM中,进而提高payload的通用性。..."+"29 Galaxy的答案: "onblur=javascript:window.onblur=al%00ert;throw"1 该挑战者使用绕过IE8/IE9 filter的一个技巧(%00),...e3rp4y的答案: "onfocus=window.onblur=top["aler"%2b"t"];throw"1 来自0×00有趣的答案: ()&xss="onclick=a=location.search
这里有一个小的知识点,就是浏览器窗体获得焦点和失去焦点,Chrome和FireFox浏览器是window的onfocus, onblur方法;而IE浏览器则是document的onfocusin, onfocusout...方法,因此有: window.onfocus = function() { }; window.onblur = function() { }; // for IE document.onfocusin...然而,这种提示有个致命的缺陷,就是用户的浏览器要一直是张开的。比方说用户浏览器最小化,标题就看不见,自然就无法及时get到有新消息的信息。...兼容性 IE14以及其他桌面浏览器都支持Web Notification,目前移动端的支持情况并不好,Android部分支持,iOS Safari浏览器全军覆没(至9.3版本): ?...其他属性值 除了Notification.permission外,Notification还有很多其他只读属性值,但是,基本上和上面的options参数一致,返回的值也是options和默认值的合并值(
] 正文从这开始~ 在React中,使用React.FocusEvent 类型来类型声明onFocus和onBlur事件。...FocusEvent接口用于onFocus和onBlur事件。...React.FocusEvent,因为FocusEvent类型用于React中的onFocus和onBlur事件。...然而,我们在输入事件时可以更具体一些。找出事件类型的最简单方法是内联编写事件处理,并将鼠标悬停在函数中的event参数上。...现在我们知道了示例中onFocus和 onBlur的正确类型,是React.FocusEvent 。我们可以提取我们的处理函数。
封装一个函数,函数中判断浏览器的类型: ?...5.有些事件是没有冒泡的,比如onblur、 onfocus. onmouseenter. onmouseleave 6.事件冒泡有时候会带来麻烦,有时候又会帮助很巧妙的做某些事件,我们后面讲解。...事件对象的兼容性处理 事件对象本身的获取存在兼容问题: 标准浏览器中是浏览器给方法传递的参数,只需要定义形参 e 就可以获取到。...在 IE6~8 中,浏览器不会给方法传递参数,如果需要的话,需要到 window.event 中获取查找。...1.8 事件委托 事件冒泡本身的特性,会带来的坏处,也会带来的好处。 什么是事件委托 把事情委托给别人,代为处理。 事件委托也称为事件代理,在 jQuery 里面称为事件委派。
作者:WEBING segmentfault.com/a/1190000014700549 一、预加载图像 如果你的网页中需要使用大量初始不可见的(例如,悬停的)图像,那么可以预加载这些图像。 ?...二、检查图像是否加载 有时为了继续脚本,你可能需要检查图像是否全部加载完毕。 ? 你也可以使用 ID 或 CLASS 替换 标签来检查某个特定的图像是否被加载。...三、自动修复破坏的图像 逐个替换已经破坏的图像链接是非常痛苦的。不过,下面这段简单的代码可以帮助你。 ? 四、悬停切换 当用户鼠标悬停在可点击的元素上时,可添加类到元素中,反之则移除类。 ?...实现 $('#ele').click(function(event){ //获取鼠标在图片上的坐标 console.log('X:' + event.offsetX+'\n Y:' + event.offsetY...还有一种方法是在(前缀$)变量中高速缓存元素 ? 链式和高速缓存的方法都是 jQuery 中可以让代码变得更短和更快的最佳做法。
一、预加载图像 如果你的网页中需要使用大量初始不可见的(例如,悬停的)图像,那么可以预加载这些图像。 ? 二、检查图像是否加载 有时为了继续脚本,你可能需要检查图像是否全部加载完毕。 ?...四、悬停切换 当用户鼠标悬停在可点击的元素上时,可添加类到元素中,反之则移除类。 ? 只需要添加必要的 CSS 即可。更简单的方法是使用 toggleClass() 方法。 ?...实现 $('#ele').click(function(event){ //获取鼠标在图片上的坐标 console.log('X:' + event.offsetX+'\n Y:' +...三十一、链式插件调用 jQuery 允许“链式”插件的方法调用,以减轻反复查询 DOM 并创建多个 jQuery 对象的过程。 ? 通过使用链式,可以改善 ?...还有一种方法是在(前缀$)变量中高速缓存元素 ? 链式和高速缓存的方法都是 jQuery 中可以让代码变得更短和更快的最佳做法。
(此时原生 DOM 事件早已冒出document了): react 16 delegation 因此,不同版本的 React 组件嵌套使用时,e.stopPropagation()无法正常工作(两个不同版本的事件系统是独立的...() 另一方面,将事件系统从document缩回来,也让 React 更容易与其它技术栈共存(至少在事件机制上少了一些差异) 向浏览器原生事件靠拢 此外,React 事件系统还做了一些小的改动,使之更加贴近浏览器原生事件...: onScroll不再冒泡 onFocus/onBlur直接采用原生focusin/focusout事件 捕获阶段的事件监听直接采用原生 DOM 事件监听机制 注意,onFocus/onBlur的下层实现方案切换并不影响冒泡... 传播过程之外的事件对象上的所有状态会被置为null,除非手动e.persist()(或者直接做值缓存) React 17 去掉了事件复用机制,因为在现代浏览器下这种性能优化没有意义...; } 在后来的迭代中却没对forwardRef、memo加以检查,在 React 17 补上了。
实际开发中我们很少使用事件捕获,我们更关注事件冒泡。 5. 有些事件是没有冒泡的,比如 onblur、onfocus、onmouseenter、onmouseleave 6....事件冒泡有时候会带来麻烦,有时候又会帮助很巧妙的做某些事件。...: 标准浏览器中是浏览器给方法传递的参数,只需要定义形参 e 就可以获取到。...在 IE6~8 中,浏览器不会给方法传递参数,如果需要的话,需要到 window.event 中获取查找。...什么是事件委托 把事情委托给别人,代为处理。 事件委托也称为事件代理,在 jQuery 里面称为事件委派。 说白了就是,不给子元素注册事件,给父元素注册事件,把处理代码在父元素的事件中执行。