<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"/> <title>Document</title> </head> <body> <p id='p'>test<p> <form> <input type='submit' value='Submit Form' > </form> <form> <button type='submit' name="submit-btn" autofocus>Submit Form</button> </form> <form name='form2'> <input type='image' src='2.jpg' width='15%'height='15%'> </form> <form> <input type='reset' value='Rest From'> <button type='reset'>Rest From</button> </form> <form> <select> <option value ="volvo">Volvo</option> <option value ="saab">Saab</option> <option value="opel">Opel</option> <option value="audi">Audi</option> </select> </form> <form> <!-- 行间添加JavaScript代码,解决IE下mouseout不能取消焦点问题 标准下获得焦点可以select()取消焦点blur() 非标准下获得焦点select()取消焦点 this.value = this.value --> <input id="txtId" type="text" value="over out" onmouseover="javascript:this.select();" onmouseout="javascript:this.blur()||(this.value=this.value);"/> </form> <form> <textarea rows='15' cols='15' style='resize:none'>121545sd2154521212312313213</textarea> </form> <script type="text/javascript"> var EventUtil = { addHandler: function(element,type,handler){//添加事件 if (element.addEventListener) { element.addEventListener(type,handler,false); }else if (element.attachEvent) { element.attachEvent('on'+type,function(){ //做的IE兼容 handler.call(element); }); }else { element['on'+type] = handler; } }, getEvent: function(event){//获得事件对象 return event || window.event; }, getTarget: function(event){//获得事件元素 return event.target || event.srcElement; }, preventDefault: function(){//取消默认事件行为 if (event.preventDefault) { event.preventDefault(); }else { event.returnValue = false; } }, removeHandler: function(element,type,handler){//取消事件 if (element.removeEventListener) { element.removeEventListener(type,handler,false) }else if (element.dettchEvent) { element.dettchEvent('on'+type,handler); }else { element['on'+type] = null; } }, stopPropagation: function(event){//取消冒泡机制 if (event.stopPropagation) { event.stopPropagation(); }else { event.cancleBubble = true; } }, getRelatedTarget: function(event){ if (event.relatedTarget) { return event.relatedTarget;//标准下返回相关元素 }else if (event.toElement) { return event.toElement;//mouseout事件触发,保存相关元素 }else if (event.fromElement) { return event.fromElement;//mouseover事件触发,保存相关元素 } }, getButton: function(event){//鼠标按钮兼容 if (document.implementation.hasFeature('MouseEvents','2.0'))//标准下 { return event.button; }else { switch (event.button)//非标准下 { case 0: case 1: case 3: case 5: case 7: return 0; case 2: case 6: return 2; case 4: return 1; } } }, getWheelDelta: function(event){//滚轮事件兼容 //所以要兼容,写两个函数函数 //client的兼容性必须先写出来 if (event.wheelDelta) { /* 兼容opear9.5以前版本的正负相反,mousewheel */ return (window.client.engine.opera && window.client.engine.opera < 9.5 ? -event.wheelDelta : event.wheelDelta); }else { /* 兼容firefox正负和3的倍数的问题,DOMMouseScroll */ return -event.detail*40; } }, getCharCode: function(event){//键盘事件兼容 if (typeof event.charCode == 'number')//首先检测按键有没有代表的字符,如果没有就没有charCode,为undefined { return event.charCode; }else { return event.keyCode } } }; var af = document.forms; /* function sub(event){ event = EventUtil.getEvent(event); var target = EventUtil.getTarget(event); //target.elements获得是一个集合可以用下表取得也可以用名字获得 var btn = target.elements['submit-btn']; document.body.innerHTML += btn ; //禁用提交 btn.disable = true; } EventUtil.addHandler(af[1],'submit',sub) //刷新网页设置聚焦的元素 //如果input元素type属性为hidden或css的display和visibility属性隐藏了该字段,同样也会导致错误 EventUtil.addHandler(window,'load',function(event){ document.forms[1].elements['submit-btn'].focus(); }); //元素可以添加autofocus来自动聚焦,如果添加了ele.autofocus === true //检测是否设置了autofocus,autofocus是布尔值 EventUtil.addHandler(window,'load',function(event){ var element = document.forms[1].elements['submit-btn']; if (element.autofocus !== true) { element.focus(); console.log( 'JS focus' ); } }); //获得焦点,然后文本框变色,或者触发change事件,检测输入的内容是否合法 var textBox = document.forms[document.forms.length-1].elements[0]; console.log( textBox ); EventUtil.addHandler(textBox,'focus',change1); EventUtil.addHandler(textBox,'blur',change2); EventUtil.addHandler(textBox,'change',change3); function change1(event){ event = EventUtil.getEvent(event); var target = EventUtil.getTarget(event); if (target.style.background === '') { target.style.background = 'yellow'; } } function change2(event){ event = EventUtil.getEvent(event); var target = EventUtil.getTarget(event); if (/[^d]/.test(target.value)) { target.style.background = 'red'; }else { target.style.background = ''; } } function change3(event){ event = EventUtil.getEvent(event); var target = EventUtil.getTarget(event); console.log(1) if (/[^d]/.test(target.value)) { target.style.background = 'red'; }else { target.style.background = ''; } } */ /* //非标准下聚焦的触发事件 var textBox = af[af.length-1].elements[0]; EventUtil.addHandler(textBox,'focus',change); function change(event){ event = EventUtil.getEvent(event); var target = EventUtil.getTarget(event); target.select(); } */ //这里不能使用select触发,虽然标准下可以正常,但是IE兼容的不行他会在刚一触发就执行 //所以只能用mouseup触发 var textBox = af[af.length-1].elements[0]; EventUtil.addHandler(textBox,'mouseup',fn); function fn(event){ var that = this; //ie兼容 var a = compa(that); alert(a); } //兼容函数 function compa(that){ if (typeof that.selectionStart === 'number') { return that.value.substring(that.selectionStart,that.selectionEnd); }else { //document.selection.createRange()为一个对象 return document.selection.createRange().text; } } alert(blur in window) </script> </body> </html>
选择部分文本
标准下的实现方法:
var textBox = document.forms[0].elements[0]; //在调用setSelectionRange()之前或之后立即将焦点设置到文本上 EventUtil.addHandler(textBox,'dblclick',fn) function fn(event){ event = EventUtil.getEvent(event); var target = EventUtil.getTarget(event); target.setSelectionRange(0,textBox.value.length); }
非标准下的实现方法(ie8以下)
var textBox = document.forms[0].elements[0]; var range = textBox.createTextRange();//创建一个对象并指定其范文 range.collapse(true);//选择所有的文本 range.moveStart('character',0);//以字符为单位,从0位开始 它指定的单位有character(字符)、word(词)、sentence(段落)、textedit range.moveEnd('character',textBox.value.length);//以字符为单位,最后一位 range.select();//xuanze
JS moveStart和moveEnd方法(TextRange对象--查找与选择)详解
boundingHeight 获取绑定TextRange对象的矩形的高度
boundingLeft 获取绑定TextRange 对象的矩形左边缘和包含TextRange对象的左侧之间的距离
offsetLeft 获取对象相对于版面或由offsetParent属性指定的父坐标的计算左侧位置
offsetTop 获取对象相对于版面或由offsetParent属性指定的父坐标的计算顶端位置
htmlText 获取绑定TextRange对象的矩形的宽度
text 设置或获取范围内包含的文本
方法
moveStart 更改范围的开始位置
moveEnd 更改范围的结束位置
collapse 将插入点移动到当前范围的开始或结尾
move 折叠给定文本范围并将空范围移动给定单元数
execCommand 在当前文档、当前选中区或给定范围上执行命令
select 将当前选择区置为当前对象
findText 在文本中搜索文本并将范围的开始和结束点设置为包围搜索字符串。
使用TextRange对象通常包括三个基本的步骤:
1.创建文本范围
2.设置开始点和结束点
3.对范围进行操作
兼容版本
var textbox = document.forms[0].elements[0]; function selectText(textbox,startIndex,stopIndex){ //为的是在填入的值为负值时,显示一致 startIndex = startIndex < 0 ? -startIndex : startIndex; stopIndex = stopIndex < 0 ? textbox.value.length : stopIndex; if (textbox.setSelectionRange) { textbox.setSelectionRange(startIndex,stopIndex); }else if (textbox.createTextRange) { var range = textbox.createTextRange(); range.collapse(true); range.moveStart('character',startIndex); range.moveEnd('character',stopIndex - startIndex); range.select(); } textbox.focus(); } selectText(textbox,1,16)