`
heartnn
  • 浏览: 34853 次
  • 性别: Icon_minigender_1
  • 来自: 石家庄
文章分类
社区版块
存档分类
最新评论

利用jQuery实现文本框的聚焦

阅读更多
作者:Realazy

先说明我们的目的。我们知道,当代浏览器(modern browsers)的文本框的聚焦(focus)样式可以通过CSS的伪类:focus来设置。假设我们有这么一段代码:

<form>
<dl>
<dt>Name: <dt>
<dd><input type="text" /></dd>
<dt>Password: <dt>
<dd><input type="password" /></dd>
<dt>Textarea: <dt>
<dd><textarea></textarea></dd>
</dl>
</form>

则我们这样的CSS就可以搞定focus样式:

input[type="text"]:focus, input[type="password"]:focus, textarea:focus { border: 1px solid #f00; background: #fcc; }

简单不过,对不?你可以拿任何一款当代浏览器来测试(Firefox, Safari, IE7):

<!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" xml:lang="zh-CN">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Step 1 | jQuery Tutorial</title>
<style type="text/css" media="screen">
body { font: .9em/1.5 "Lucida Grande", "Trebuchet MS", "Bitstream Vera Sans", Verdana, Helvetica, sans-serif; }
form { width: 20em; margin: 4em auto; }
dt { clear: left; float: left; }
dd { clear: right; margin-left: 6em; }
input[type="text"], input[type="password"], textarea { width: 12em; border: 1px solid #ccc; }
input[type="text"]:focus, input[type="password"]:focus, textarea:focus { border: 1px solid #f00; background: #fcc; }
</style>
</head>
<body>
<form>
<dl>
<dt>Name: <dt>
<dd><input type="text" /></dd>
<dt>Password: <dt>
<dd><input type="password" /></dd>
<dt>Textarea: <dt>
<dd><textarea></textarea></dd>
</dl>
</form>
</body>
</html>

IE6? 呵呵,这就是本篇教程的目的所在,没错,既然IE不支持:focus,我们只能Using DOM Scripting to Plug the Holes in CSS,不过我们用jQuery来实现。

先来看看jQuery的工作方式。jQuery使用美元符号$来返回一个jQuery对象,然后我们就可以使用jQuery提供的API(接口。很多很多很实用,赶紧参考Visual JQuery)进行操作了。

我们都不懂程序,对,我假设你跟我这样,只是了解一些最基本的语法(对不起大虾了,高手不要自扁身份)。既然我们不懂,我们就用CSS的方式来思维。

首先我们要从DOM中获得type="text", type="password"的input和textarea。对,我们伟大的美金出场了,哦,是美元符号。参考http://proj.jquery.com/docs/Base/Expression/CSS/,我们知道,我们可以这样选择到他们:

$("input[@type='text'], input[@type='password'], textarea")

选中它们以后呢?我们就要靠事件(event)来处理了。:focus对应的的事件是onfocus,然而jQuery讨厌on,于是就是focus了,多好 :) (参考http://proj.jquery.com/docs/EventModule/)。于是我们知道我们该这么做:

$("input[@type='text'], input[@type='password'], textarea").focus();

嘿嘿,我们已经迈出一大步了!我们要继续告诉focus该做些什么。在jQuery中,我们通常需要一些匿名函数来帮我们干些事情,不理解不打紧,让我们继续:

$("input[@type='text'], input[@type='password'], textarea").focus( function(){ } );

我们的目的是什么?对,是给聚焦的文本框加上样式。jQuery有一个css (prop)的API,参考前面的CSS,我们可以这么写:

css({background:"#fcc", border:"1px solid #f00"})

bingo! 离成功仅一步之遥。我假设你知道,返回对象自身使用this。在jQuery中,返回自身当然也是this, 但是,需要返回的对象还是jQuery对象,我们还必须使用美元符号。所以是$(this)。那么:

$("input[@type='text'], input[@type='password'], textarea").focus( function(){ $(this). css({background:”#fcc”, border:”1px solid #f00″})} );

That’s it! 然后我们该怎么执行这段代码呢? 我们知道有一个body onload=""可以用,也知道有一个window.onload可以用,但jQuery提供了一个更佳的方案,让我们可以进一步分离结构与交互。

$(document).ready(function(){
// Your code here...
});

所以我们只需将我们的代码放到里面去:

$(document).ready(function(){
$("input[@type='text'], input[@type='password'], textarea").focus( function(){ $(this). css({background:"#fcc", border:"1px solid #f00"})} );
});

呵呵……貌似成功了。等等,我们要送佛送到西天,好人做到底……在上面的交互中,只有聚焦的情况,那么失焦的时候呢?嗯,我们不要想当然,失焦?那么聚焦的样式就自动清楚清除了嘛~不会的,除非我们明确告诉它。依瓢画葫芦:

$(this).blur(function(){$(this).css({background: "transparent", border: "1px solid #ccc"})})

嗯,说到jQuery的强大之处了,jQuery对象可以接受无数个函数回调/消息/方法(哪一种是正确说法,请高手指教),也就是传说中的Chainability。也就是说我们不必要分两行写,一气呵成:

$(document).ready(function(){
$("input[@type='text'], input[@type='password'], textarea").focus(function(){$(this).css({background:"#fcc", border:"1px solid #f00"})}).blur(function(){$(this).css({background: “transparent”, border: “1px solid #ccc”})});
})

啊呵,又一次貌似完成……又等一等,我们只需要针对IE啊,其他浏览器都可以使用CSS来实现,我们何苦要用JS来降低它们的处理效率呢,所以,我们用了jQuery自带的定义:

$(document).ready(function(){
if ($.browser.msie){
$(”input[@type=’text’], input[@type=’password’], textarea”).focus(function(){$(this).css({background:”#fcc”, border:”1px solid #f00″})}).blur(function(){$(this).css({background: “transparent”, border: “1px solid #ccc”})});
}
})

耶!我们真的完成了!嗯哪,要判断浏览器版本?似乎jQuery没有提供,但可以看看这个jQuery插件(plugin):jQBrowser . 嗯嗯,似乎忘了跟大家说,jQuery还拥有许多超强的插件!有时间我整理几个出来奉献给大家。

对,看看我们这一步的成果,一定记得用IE6查看。

<!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" xml:lang="zh-CN">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Step 2 | jQuery Tutorial</title>
<style type="text/css" media="screen">
body { font: .9em/1.5 "Lucida Grande", "Trebuchet MS", "Bitstream Vera Sans", Verdana, Helvetica, sans-serif; }
form { width: 20em; margin: 4em auto; }
dt { clear: left; float: left; }
dd { clear: right; margin-left: 6em; }
input, textarea { width: 12em; border: 1px solid #ccc; }
input:focus, textarea:focus { border: 1px solid #f00; background: #ffc; }
</style>
<script type="text/javascript" src="http://jqueryjs.googlecode.com/files/jquery-1.2.6.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
if ($.browser.msie){
$("input[@type='text'], input[@type='password'], textarea").focus(function(){$(this).css({background:"#fcc", border:"1px solid #f00"})}).blur(function(){$(this).css({background: "transparent", border: "1px solid #ccc"})});
}
})
</script>
</head>
<body>
<form>
<dl>
<dt>Name: <dt>
<dd><input type="text" /></dd>
<dt>Password: <dt>
<dd><input type="password" /></dd>

<dt>Textarea: <dt>

<dd><textarea></textarea></dd>
</dl>
</form>
</body>
</html>

貌似又完成了一次(汗,前边不是说我们真的完成了么),不!大家看得爽的时候还记得我是做什么的吗?对对对,是Web标准!Web标准提倡什么?结构,表现,交互相分离啊,我们把样式写到了JS里边,相信这不是好事情。难不倒我们jQuery的!我们换种思路,我们把样式在一个class里定义好,在 focus的时候加上的这个class,blur的时候去掉这个class不就OK了吗?聪明……jQuery相应的API是addClass和 removeClass。过程不累赘了,否则篇幅又得增加一半(我还要睡觉,明天还要上班,可怜的上班族),代码如下:

$(document).ready(function(){
if ($.browser.msie){
$("input[@type='text'], input[@type='password'], textarea").focus(function(){$(this).addClass("ie_focus")}).blur(function(){$(this).removeClass("ie_focus")});
}
})

我必须承认,我把这个class命名为ie_focus是有点变态。嗯,进一步,虽然我们这个代码不大,但我们也分离出来一个独立文件吧。这是我们的最后步骤的演示,记得看源码哦。

<!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" xml:lang="zh-CN">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Step 3 | jQuery Tutorial</title>
<style type="text/css" media="screen">
body { font: .9em/1.5 "Lucida Grande", "Trebuchet MS", "Bitstream Vera Sans", Verdana, Helvetica, sans-serif; }
form { width: 20em; margin: 4em auto; }
dt { clear: left; float: left; }
dd { clear: right; margin-left: 6em; }
input, textarea { width: 12em; border: 1px solid #ccc; }
input:focus, textarea:focus { border: 1px solid #f00; background: #fcc; }
.ie_hover { background: #ffc; }
.ie_focus { border: 1px solid #f00; background: #fcc; }
</style>
<script type="text/javascript" src="http://jqueryjs.googlecode.com/files/jquery-1.2.6.min.js"></script>
<script type="text/javascript" src="form_enhencement_for_ie.js"></script>
</head>
<body>
<form>
<dl>
<dt>Name: <dt>
<dd><input type="text" /></dd>
<dt>Password: <dt>
<dd><input type="password" /></dd>

<dt>Textarea: <dt>

<dd><textarea></textarea></dd>
</dl>
</form>
</body>
</html>

很简单,对不?jQuery的威力不止于此,还有需多更酷更强的功能留待你我共同探索。
分享到:
评论

相关推荐

    jQuery点击文本框下拉菜单城市选择代码

    通过这些步骤,我们可以创建一个实用且用户友好的城市选择功能,利用jQuery的强大功能来增强网页的交互性。在实际项目中,可以进一步优化此功能,例如添加动画效果、错误处理或与服务器进行异步通信,获取动态的城市...

    jquery 强制设置文本框处于英文输入法状态

    总结来说,面对“jquery 强制设置文本框处于英文输入法状态”的问题,开发人员可以利用jQuery事件处理和JavaScript的特性来控制文本框的输入模式,确保在扫描枪或其他输入设备触发时,系统不会误切换到中文输入法。...

    jquery text文本框搜索段落文本关键词文字高亮显示

    本主题聚焦于利用jQuery实现一个功能:在文本框输入关键词后,自动搜索页面中的段落文本,并高亮显示匹配到的关键字。这个功能在很多场合都非常实用,比如搜索引擎结果预览、文档阅读器或在线教育平台。 首先,我们...

    jQuery插件 文本框、文本域 光标处插入代码

    本主题聚焦于一个特定的jQuery插件,该插件允许开发者在文本框(`&lt;input type="text"&gt;`)和文本域(`&lt;textarea&gt;`)中于光标位置插入代码或内容。这对于编辑器、代码编辑器或任何需要动态插入文本的场景来说是非常...

    jquery表单文本框添加文字标签.zip

    总之,利用jQuery和HTML5的特性,我们可以轻松地为表单文本框添加动态的、交互式的文字标签,提高网页的可用性。在实际项目中,根据具体需求,还可以进一步优化和扩展这些方法,实现更多定制化的功能。

    jquery控制文本框输入密码时有短暂的显示过程

    为了消除这种现象,我们可以利用jQuery来监听键盘事件并即时处理输入。 以下是一个基本的实现步骤: 1. **选择目标元素**:使用jQuery的选择器(如`$("#passwordInput")`)来获取密码输入框的DOM元素。 2. **事件...

    jQuery实现获得焦点时文本框渐变的登录表单效果.zip

    本教程将详细讲解如何利用jQuery实现一个登录表单,在文本框获得焦点时产生渐变效果,提升用户体验。通过学习这个案例,你可以更好地理解jQuery的选择器、事件处理和CSS操作。 首先,jQuery选择器是其强大功能的...

    文本框显示描述文字

    3. 编写JavaScript:利用jQuery选择器找到相关的文本框元素,然后在其中添加或修改默认的提示文字。 4. 添加事件监听:当文本框获取焦点或失去焦点时,动态改变提示文字的显示状态。 5. 测试与调试:在不同浏览器和...

    jQuery-HTML5-CSS3实现的文本框.zip

    在文本框中,jQuery可以用来监听用户交互,如`focus`(聚焦)、`blur`(失去焦点)、`keyup`(按键释放)等事件,从而实现动态验证、提示信息显示等高级功能。例如,当用户离开文本框时,可以使用`.blur()`方法检查...

    JQ 文本框得到失去焦点

    本文将围绕“JQ文本框得到失去焦点”这一主题进行详细讲解,帮助开发者理解如何利用jQuery来监听文本框(input[type="text"])的聚焦(focus)和失焦(blur)事件。 ### 一、jQuery基本概念 jQuery库通过$函数提供...

    expandable-input:用于在文本框聚焦时展开文本框的 jQuery 插件

    3. **文本框聚焦事件**:插件的核心功能是监听文本框的`focus`事件。当用户点击或通过键盘导航到文本框时,会触发此事件。在事件处理器中,插件会改变文本框的尺寸,使其适应更多的输入内容。 4. **CSS样式调整**:...

    JQuery 文本框回车跳到下一个文本框示例代码

    在这个场景中,我们将利用jQuery选择器找到所有文本框,并监听键盘按键事件。 代码解析: 1. `loginInputForm.find('input')`:这部分是jQuery的选择器,`loginInputForm`是一个ID或者类名,用于标识包含文本框的...

    jQuery控制的表单文本框获得与失去焦点时的默认值和提示信息效果.zip

    "jQuery控制的表单文本框获得与失去焦点时的默认值和提示信息效果"这个项目就是这样一个例子,它展示了如何利用jQuery来优化表单输入元素的行为,提供更友好的用户界面。 首先,我们要理解jQuery的基本概念。jQuery...

    文本框内容focus时隐藏

    《锋利的jquery》利用val方法获取文本框内容来判断聚焦时显示还是隐藏

    基于JQuery实现鼠标点击文本框显示隐藏提示文本

    在本例中,我们将利用jQuery的`focus`和`blur`事件来监听文本框的焦点获取与失去,从而实现提示文本的显示与隐藏。 代码如下: ```javascript $(document).ready(function () { var searchBox = $("#ctl00_...

    jquery文本框显示描述文字特效代码

    本文将详细解析如何利用jQuery来创建文本框显示描述文字的特效。 首先,我们需要理解jQuery的基本用法。jQuery是一个轻量级的JavaScript库,它简化了HTML文档遍历、事件处理、动画以及Ajax交互等任务。在jQuery中,...

    jQuery设置聚焦并使光标位置在文字最后的实现方法

    例如,当一个文本框聚焦时,用户可以开始输入文字。而设置光标位置则是指在文本框中指定光标应该出现在哪个字符之后。 在jQuery中,我们可以利用`.focus()`方法来为一个元素设置聚焦。然而,这并不会自动将光标移动...

    基于jQuery实现的选中即可编辑的轻量级网页编辑器源码.zip

    本项目“基于jQuery实现的选中即可编辑的轻量级网页编辑器源码”正是利用jQuery的强大功能,构建了一个方便用户直接在网页上进行编辑的工具。以下是对这个项目的详细解析: 首先,jQuery的核心特性在于其简洁的API...

    JQ 多行文本框高度变化

    为了解决这个问题,我们可以利用jQuery来实现动态高度调整的功能。下面我们将逐步解析如何实现这一功能。 首先,我们需要在HTML中创建一个`&lt;textarea&gt;`元素,并为其分配一个唯一的ID,以便于jQuery选择器能够找到它...

    jQuery设置和移除文本框默认值的方法

    本文将详细讲解如何利用jQuery实现这一功能,并通过一个具体的实例来展示其工作原理。 首先,我们要理解jQuery的基本用法。jQuery通过选择器(如$(".input"))找到页面中的元素,然后可以对这些元素进行各种操作。...

Global site tag (gtag.js) - Google Analytics