jQuery技术

jQuery 快速入门教程(3)

字号+ 作者:H5之家 来源:H5之家 2015-10-03 15:15 我要评论( )

为了更加易于使用,jQuery提供了简洁的DOM操作API,其方法往往是读写一体的。也就是说,某个方法既可用于读取操作,也可用于设置操作。如果没有为其传入表示值的参数,则表示获取操作,将返回获取到的数据;如果为

为了更加易于使用,jQuery提供了简洁的DOM操作API,其方法往往是"读写一体"的。也就是说,某个方法既可用于读取操作,也可用于设置操作。如果没有为其传入表示值的参数,则表示获取操作,将返回获取到的数据;如果为其传入了表示值的参数,则表示设置操作,它将设置DOM元素指定属性的值。

// 返回一个匹配id为"username"的元素的jQuery对象 var uid = $("#username"); // 没有传入value参数,返回第一个匹配元素的value属性值 var value = uid.val(); // 传入了value参数,设置所有匹配元素的value值为"CodePlayer" uid.val("CodePlayer"); // 返回匹配所有包含CSS类名"foo"的div元素的jQuery对象 var div = $("div.foo"); // 没有传入value参数,返回第一个匹配元素的value元素 var fontSize = div.css("font-size"); // 传入了value参数,设置所有匹配元素的font-size样式为"14px" div.css("font-size", "14px");Get first Set all 原则

在学习jQuery的DOM操作时,我们首先应该了解一下"Get first Set all"原则。jQuery对象几乎所有的DOM操作方法都遵守"Get first Set all"原则。简而言之,假设当前jQuery对象匹配多个元素,如果使用jQuery对象的方法来获取数据("读"数据),则只会获取第一个匹配元素的数据;如果使用jQuery对象的方法来设置元素数据("写"数据),则会对所有匹配元素都进行设置操作。

var $lis = $("ul li"); // 匹配ul元素的所有后代li元素 var className = $lis.attr("class"); // 只获取第一个匹配的li元素的class属性 $lis.attr("class", "codeplayer"); // 将所有匹配的li元素的class属性设为"codeplayer"链式编程风格

jQuery还以优雅的链式编程风格著称,例如:

// jQuery的链式编程风格 $("div").find("ul").addClass("menu").children().css("margin", 0).hide(); // 以下是上述代码的分解描述 $("div") // 返回一个匹配所有div元素的jQuery对象 .find("ul") // 返回匹配这些div元素中的所有后代ul元素的jQuery对象 .addClass("menu") // 为这些ul元素添加CSS类名"menu",并返回当前对象本身 .children() // 返回匹配这些ul元素中的所有子代元素的jQuery对象 .css("margin", 0) // 为这些子代元素设置css样式"margin: 0",并返回当前对象本身 .hide(); // 隐藏这些子代元素,并返回当前对象本身

显然,这种链式编程风格的实现机制,就是jQuery对象的所有实例方法,在没有特殊的返回需求的情况下,一般都会返回该jQuery对象本身(或者其它jQuery对象),因此我们可以继续调用返回的jQuery对象上的方法。

$("#uid").val()、 $("div").attr("id") 等方法在没有传入值参数时,它们将返回指定DOM元素的特定属性值,它们有特定的返回需求,因此无法进行链式编程。如果是$("#uid").val("CodePlayer")、 $("div").attr("id", "myId")等情况,此时它们不需要返回特定的值,将返回当前jQuery本身,因此可用于链式编程。智能DOM操作,静默容错

在JS原生DOM操作中,如果通过getElementById()、getElementsByName()等方式获取不到对应的元素,那么将返回null,在null上访问属性或方法,将会抛出异常。

与此不同的是,jQuery在匹配不到对应元素时将返回一个空的jQuery对象,我们仍然可以调用jQuery对象的方法,而且并不会报错。因为jQuery会智能地处理这种情况。如果该方法用于获取数据,则返回null或undefined;如果该方法用于设置数据,则忽略设置操作,并返回该空对象本身;如果该方法用于筛选元素,则同样返回一个新的jQuery空对象。

因此,你可以放心大胆地使用jQuery进行链式编程。

// 没有标签为abc的DOM元素,$("abc")是一个空的jQuery对象,调用其find()方法将返回一个新的jQuery空对象 var a = $("abc").find("p"); // 如果不存在id为notFound的元素,$("#notFound")是一个空的jQuery对象,获取其id属性,将返回undefined。 var b = $("#notFound").attr("id"); // 如果不存在id为notFound的元素,$("#notFound")是一个空的jQuery对象,获取其高度值,将返回null。 var c = $("#notFound").height(); // 如果不存在id为uname的元素,$("#uname")是一个空的jQuery对象,设置其value值,将忽略该设置操作,并返回该空对象本身 var d = $("#uname").val("xxxxx");jQuery核心:DOM操作

在前面我们学习了如何选取元素,也了解了jQuery进行DOM操作的一些原则。下面,我们就来真正使用jQuery的DOM操作方法了。

属性操作

在jQuery中,对DOM元素进行属性操作,主要是通过以下方法实现的:

// selector 表示具体的选择器 $("selector").val(); // 获取第一个匹配元素的value值(一般用于表单控件) $("selector").val("Hello"); // 设置所有匹配元素的value值为"Hello" $("selector").html(); // 获取第一个匹配元素的innerHTML值 $("selector").html("Hello"); // 设置所有匹配元素的innerHTML值为"Hello" $("selector").text(); // 获取第一个匹配元素的innerText值(jQuery已进行兼容处理) $("selector").text("Hello"); // 设置所有匹配元素的innerText值为"Hello" $("selector").attr("class"); // 获取第一个匹配元素class属性 $("selector").attr("class", "code"); // 设置所有匹配元素的class属性为"code" $("selector").removeAttr("class"); // 移除所有匹配元素的class属性 $("selector").prop("checked"); // 获取第一个匹配元素的checked属性值 $("selector").prop("checked", true); // 设置所有匹配元素的checked属性值为true(意即选中所有匹配的复选框或单选框) $("selector").removeProp("className"); // 移除所有匹配元素的className属性

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 7个有用的jQuery小技巧

    7个有用的jQuery小技巧

    2016-02-26 13:02

  • jQuery制作select双向选择列表

    jQuery制作select双向选择列表

    2016-02-26 11:00

  • 全面详细的jQuery常见开发技巧手册

    全面详细的jQuery常见开发技巧手册

    2016-02-26 10:02

  • 强大的jQuery移动插件Top 10

    强大的jQuery移动插件Top 10

    2016-02-25 09:05

网友点评
"