一篇jQuery小教程

作者:Realazy 来源:Realazy 时间:2007-10-15 12:49:00 

写个小教程,以期能让大家对jQuery有所了解,甚至喜欢上它(请不要怪我)。

不废话,先说明我们的目的。我们知道,当代浏览器(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): http://realazy.org/lab/jquery/tut/form_hover_step1.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"inputtextarea。对,我们伟大的美金出场了,哦,是美元符号。参考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,focus
0
投稿

猜你喜欢

  • Python实现ping指定IP的示例

    2023-10-05 04:20:10
  • Pycharm配置远程调试的方法步骤

    2021-03-13 00:45:38
  • 浅谈PHP的$_SERVER[SERVER_NAME]

    2024-05-03 15:48:46
  • Python中模块string.py详解

    2021-05-20 05:25:03
  • python实现统计代码行数的方法

    2021-06-23 11:24:17
  • Python自动化办公之创建PPT文件

    2022-01-16 19:31:49
  • Python requests.post()方法中data和json参数的使用方法

    2022-10-10 04:25:45
  • 用来将对象持久化的python pickle模块

    2023-11-01 02:28:45
  • SQL中Group分组获取Top N方法实现可首选row_number

    2024-01-13 11:22:45
  • javascript增加干扰数据实现简单加密效果

    2011-02-24 11:07:00
  • Python自定义进程池实例分析【生产者、消费者模型问题】

    2023-05-20 12:20:02
  • python下PyGame的下载与安装过程及遇到问题

    2021-09-24 00:12:15
  • 如何创建CSS的对象,获取合适的粒度

    2010-07-09 13:10:00
  • Python利用pynput实现划词复制功能

    2022-03-28 23:14:23
  • torch.utils.data.DataLoader与迭代器转换操作

    2021-01-18 11:02:34
  • Python类中的魔法方法之 __slots__原理解析

    2023-10-01 18:49:51
  • 在Python的Flask框架中构建Web表单的教程

    2023-10-04 06:03:12
  • SQLite数据库管理相关命令的使用介绍

    2024-01-27 12:41:00
  • python-docx 页面设置详解

    2021-12-06 03:42:02
  • Python读取xlsx数据生成图标代码实例

    2022-01-11 11:35:56
  • asp之家 网络编程 m.aspxhome.com