教程集 www.jiaochengji.com
教程集 >  jQuery  >  jquery 教程  >  正文 jquery聚焦文本框与扩展文本框聚焦方法

jquery聚焦文本框与扩展文本框聚焦方法

发布时间:2013-09-28   编辑:jiaochengji.com
在不同的浏览器中,一个文本框,如果只是直接给文本框设置focus(),那么光标聚焦的位置可能是在最前面。下面的代码则是给jquery扩展一个textFocus方法
光标聚焦的位置在最前面
复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>jquery聚焦文本框 -脚本之家</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js" type="text/javascript"></script>
</head>
<body>
<form action="http://www.baidu.com" id="cse-search-box">
<div>
<input type="hidden" name="cx" value="partner-pub-7740261255677392:7064996710" />
<input type="hidden" name="ie" value="UTF-8" />
<!--文本框--><input type="text" name="q" size="25" />
<input type="submit" name="sa" value="搜索" />
</div>
</form>
<script type="text/javascript">
$(document).ready(function () {
$("input[name='q']").focus();
})</script>
</body>
</html>


jquery扩展文本框聚焦方法

在不同的浏览器中,一个文本框,如果只是直接给文本框设置focus(),那么光标聚焦的位置可能是在最前面。下面的代码则是给jquery扩展一个textFocus方法,用于聚焦文本框,并使光标在最后,使用$("input").textFocus()。也可以传入一个数字参数,设置光标聚焦的位置。如$("input").textFocus(2),则光标在在第二个字符后面。
复制代码 代码如下:

(function($){
$.fn.textFocus=function(v){
var range,len,v=v===undefined?0:parseInt(v);
this.each(function(){
if($.browser.msie){
range=this.createTextRange(); //文本框创建范围
v===0?range.collapse(false):range.move("character",v); //范围折叠
range.select(); //选中
}else{
len=this.value.length;
v===0?this.setSelectionRange(len,len):this.setSelectionRange(v,v); //dom直接设置选区,然后focus
}
this.focus();
});
return this;
}
})(jQuery)

您可能感兴趣的文章:
jquery聚焦文本框与扩展文本框聚焦方法
jquery设置焦点方法focus()和jquery失去焦点方法blur()
js将光标聚焦在文本最后怎么实现
jquery 设置文本框、密码框获得焦点时的样式
JQuery文本改变触发事件如聚焦事件、失焦事件
基于jquery实现的移入页面上空文本框时,让它变为焦点,移出清除焦点
Jquery实现获取焦点、失去焦点的代码
jQuery回车键切换文本框焦点
jQuery限制只能输入数字与失去焦点获取焦点
jquery中focus()函数实现当对象获得焦点后自动把光标移到内容最后

关键词: 聚焦文本框   
[关闭]
~ ~