How to Use jQuery
jQuery的加载
一般采用以下方式 加载jQuery库 //表示同时支持http协议和https协议。
1 2 3 4 5 6 7 8 9
| <script type="text/javascript" src="//code.jquery.com/jquery-1.11.0.min.js"> </script> <script> window.jQuery || document.write( '<script src="js/jquery-1.11.0.min.js" type="text/javascript"><\/script>' ); </script>
|
jQuery基础
jQuery常用选择器
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
| $("#uid"); // 选取id属性为"uid"的单个元素 $("p"); // 选取所有的p元素 $(".test"); // 选择所有带有CSS类名"test"的元素 $("[name=books]"); // 选择所有name属性为"books"的元素
// 多个选择器以空格或指定符号隔开,将匹配与前者具有指定关系的最后一个选择器所表示的元素 $("#uid span"); // 选择id为"uid"的元素的所有后代span元素 $("p > span"); // 选择p元素的所有子代span元素 $("div + p"); // 选择div元素后面紧邻的同辈p元素 $("div p span"); // 选择div元素的所有后代p元素的后代span元素
// 多个选择器之间没有空格,将匹配同时满足这些选择器条件的元素 $("p#uid"); // 选择id属性为"uid"的p元素 $("div.foo"); // 选择所有带有CSS类名"foo"的div元素 $(".foo.bar"); // 选择所有同时带有CSS类名"foo"和"bar"的元素 $("input[name=books][id]"); // 选择所有name属性为"books"并且具备id属性的元素
// jQuery特有的选择器,当然也可以和其他选择器任意组合使用 $(":checkbox"); // 选取所有的checkbox元素 $(":text"); // 选取所有type为text的input元素 $(":password"); // 选取所有type为password的input元素 $(":checked"); // 选取所有选中的radio、checkbox、option元素 $(":selected"); // 选取所有选中的option元素 $(":input"); // 选取所有的表单控件元素(所有input、textarea、select、button元素)
|
jQuery元素帅选
1 2 3 4 5 6 7 8 9 10 11 12 13
| // 以下方法都返回一个新的jQuery对象,他们包含筛选到的元素 $("ul li").eq(1); // 选取ul li中匹配的索引顺序为1的元素(也就是第2个li元素) $("ul li").first(); // 选取ul li中匹配的第一个元素 $("ul li").last(); // 选取ul li中匹配的最后一个元素 $("ul li").slice(1, 4); // 选取第2 ~ 4个元素 $("ul li").filter(":even"); // 选取ul li中所有奇数顺序的元素 $("div").find("p"); // 选取所有div元素的所有后代p元素 $("div").children(); // 选取所有div元素的所有子代元素 $("div").children("p"); // 选取所有div元素的所有子代p元素 $("span").parent(); // 选取所有span元素的父元素 $("span").parent(".foo.bar"); // 选取所有span元素的带有CSS类名"foo"和"bar"的父元素 $("#uid").prev(); // 选取id为uid的元素之前紧邻的同辈元素 $("#uid").next(); // 选取id为uid的元素之后紧邻的同辈元素
|
jQuery核心:DOM操作
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| // 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 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| // 以下$A均表示当前jQuery对象,$B可以是选择器字符串、html字符串、DOM元素、jQuery对象
$A.before( $B ); // 在$A之前插入$B $A.after( $B ); // 在$A之后插入$B
$A.insertBefore( $B ); // 将$A插入到$B之前的位置 $A.insertAfter( $B ); // 将$A插入到$B之后的位置
$A.append( $B ); // 在$A内部的末尾位置追加$B $A.appendTo( $B ); // 将$A追加到$B内部的末尾位置
$A.prepend( $B ); // 在$A内部的开头位置追加$B $A.prependTo( $B ); // 将$A追加到$B内部的开头位置
$A.replaceAll( $B ); // 用$A替换$B $A.replaceWith( $B ); // 用$B替换$A
$A.wrap( $B ); // 在$A的外侧包裹$B $A.unwrap( ); // 只移除$A的父元素的标签 $A.wrapAll( $B ); // 在整个$A的外侧用单个$B将其包裹起来 $A.wrapInner( $B ); // 在$A的内侧包裹$B
$A.empty(); // 清空$A的所有内容 $A.remove(); // 删除$A及其绑定的事件、附加数据等 $A.detach(); // 删除$A,但保留其绑定的事件、附加数据等
$A.clone(); // 克隆一个$A
|
CSS操作
1 2 3 4 5 6 7
| $("selector").css("margin-left"); // 获取第一个匹配元素的margin-left的属性值 $("selector").css("marginLeft"); // 与上一行代码作用相同,css()支持这两种写法
$("selector").css("marginLeft", 15); // 设置所有匹配元素的margin-left为15px(数字的默认单位均为px) $("selector").css( { marginLeft: 15, color: "red", fontSize: "14px"} ); // 一次性设置所有匹配元素的多个样式属性
$("selector").css( "marginLeft", ""); // 设为空字符串,则表示删除该样式属性
|
动画效果
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
| $("selector").show(); // 显示隐藏的元素,默认不带过渡动画效果 $("selector").show( 400 ); // 显示隐藏的元素,带有400毫秒的过渡动画效果 $("selector").show( "fast" ); // 显示隐藏的元素,带有200毫秒的过渡动画效果 $("selector").show( "slow" ); // 显示隐藏的元素,带有600毫秒的过渡动画效果
$("selector").hide(); // 隐藏显示的元素,其用法与show()相同 $("selector").toggle(); // 切换显示/隐藏元素(如果显示就隐藏,隐藏就显示),其用法与show()类似
/* 下面的slide*、fade*系列方法与上面的show()、hide()、toggle()等方法作用相同, * 用法也类似,只是带有不同的动画效果 */
$("selector").slideDown(); // 显示隐藏的元素,带有向下滑动的过渡动画效果 $("selector").slideUp(); // 隐藏显示的元素,带有向上滑动的过渡动画效果 $("selector").slideToggle(); // 切换显示/隐藏的元素,带有向上/下滑动的过渡动画效果
$("selector").fadeIn(); // 显示隐藏的元素,带有淡入的过渡动画效果 $("selector").fadeOut(); // 隐藏显示的元素,带有淡出的过渡动画效果 $("selector").fadeToggle(); // 隐藏显示的元素,带有淡出的过渡动画效果
// 设置所有匹配元素的css样式"width: 200px; height: 100px",并执行一个当前样式到指定样式的过渡动画效果 // 动画的执行时间为 1000 毫秒 $("selector").animate( { width: "200px", height: "100px" }, 1000 );
|