1. jQuery
jQuery 其实就是一堆的js函数,是普通的js,只不过应用广泛,形成了行业标准。
2. jQuery的重点
2.1 jQuery入口函数(全球都会)
2.2 jQuery的选择器(其实就是CSS的选择器)
2.3 jQuery的Dom操作
2.4 jQuery的样式操作
2.5 jQuery的动画
2.6 jQuery的事件处理
3.jQuery的入口函数
3.1 语法
jQuery(document).read(function(){ });
$(function(){ });// **
window.onlaod = function(){}
===jQuery//是jQuery全局函数的别名。
3.2注意事项: (重点)
document ready: 是html文档准备就绪,也就是dom树创建完成了。可以进行dom操作了。 重要的是:html页面下载完成,并准备就绪
window.onload: 是整个页面所有的资源都加载完成,图片、js、css等…
3.3 文档加载顺序: (重点)
下载html页面,解析html标签,遇到link标签加载css,遇到script加载js..
jQuery入口函数与js入口函数的对比:
javaScript的入口函数要等到页面中所有资源(包括图片、文件)加载完成才开始执行。
jQuery的入口函数只会等待文档树加载完成就开始执行,并不会等待图片、文件的加载。
4. jQuery 选择选取元素
4.1 jQuery选择器
4.1.1 ID选择器(js一般尽量用ID选择器,效率最高)
(重点)
$(“#id”).html();
4.1.2 类选择器
(重点)
$(“.className”).text();
4.1.3 标签选择器
(重点)
$(‘p’).click();
4.1.4 属性选择器
("li[id]")、(“li[id=’link’]”).fadeIn();
4.1.5 层级选择器
(重点)
$(“li .link”).show();
4.1.6 父子选择器
$(“ul > li”)
4.1.7 伪类选择器
$(“p:first”)
$(“ul li:eq(3)”)
4.1.8 表单选择器
$(“:text”)
$(“:checkbox”)
$(“:checked”)
4.2 选择器汇总
* $("*") 所有元素
#id $("#lastname") id="lastname" 的元素
.class $(".intro") 所有 class="intro" 的元素
element $("p") 所有 <p> 元素
.class.class $(".intro.demo") 所有 class="intro" 且 class="demo" 的元素12345
:first $("p:first") 第一个 <p> 元素
:last $("p:last") 最后一个 <p> 元素
:even $("tr:even") 所有偶数 <tr> 元素
:odd $("tr:odd") 所有奇数 <tr> 元素1234
:eq(index) $("ul li:eq(3)") 列表中的第四个元素(index 从 0 开始)
:gt(no) $("ul li:gt(3)") 列出 index 大于 3 的元素 greater than
:lt(no) $("ul li:lt(3)") 列出 index 小于 3 的元素 less than
:not(selector) $("input:not(:empty)") 所有不为空的 input 元素
:header $(":header") 所有标题元素 <h1> - <h6>
:animated 所有动画元素1234567
:contains(text) $(":contains('W3School')") 包含指定字符串的所有元素
:empty $(":empty") 无子(元素)节点的所有元素
:hidden $("p:hidden") 所有隐藏的 <p> 元素
:visible $("table:visible") 所有可见的表格
:has(selector) $('td:has("span")') 匹配包含选择器所匹配的元素的元素
:parent $('td:parent') 匹配含有子元素或者文本的元素
s1,s2,s3 $("th,td,.intro") 所有带有匹配选择的元素123456
[attribute] $("[href]") 所有带有 href 属性的元素
[attribute=value] $("[href='#']") 所有 href 属性的值等于 "#" 的元素
[attribute!=value] $("[href!='#']") 所有 href 属性的值不等于 "#" 的元素
[attribute^=value] $("[href^='#']") 所有 href 属性的值以 "#"开头的元素
[attribute*=value] $("[href*='#']") 所有 href 属性的值包含 "#" 的元素
[attribute$=value] $("[href$='.jpg']") 所有 href 属性的值包含以 ".jpg" 结尾的元素1234
:input $(":input") 所有 <input> 元素
:text $(":text") 所有 type="text" 的 <input> 元素
:password $(":password") 所有 type="password" 的 <input> 元素
:radio $(":radio") 所有 type="radio" 的 <input> 元素
:checkbox $(":checkbox") 所有 type="checkbox" 的 <input> 元素
:submit $(":submit") 所有 type="submit" 的 <input> 元素
:reset $(":reset") 所有 type="reset" 的 <input> 元素
:button $(":button") 所有 type="button" 的 <input> 元素
:image $(":image") 所有 type="image" 的 <input> 元素
:file $(":file") 所有 type="file" 的 <input> 元素12345678910
:enabled $(":enabled") 所有激活的 input 元素
:disabled $(":disabled") 所有禁用的 input 元素
:selected $(":selected") 所有被选取的 input 元素
:checked $(":checked") 所有被选中的 input 元素1234
4.3 jQuery选择方法
4.3.1 获取父级元素
* $(selector).parent(); //获取直接父级
* $(selector).parents('p'); //获取所有父级元素直到html 12
4.3.2 获取子代和后代的元素
* $(selector).children(); //获取直接子元素
* $(selector).find("span"); //获取所有的后代元素
* find方法 可能用的多。123
4.3.3 获取同级的元素
* $(selector).siblings() //所有的兄弟节点
* $(selector).next() //下一个节点
* $(selector).nextAll() //后面的所有节点
* $(selector).prev() //前面一个的兄弟节点
* $(selector).prevAll() //前面的所有的兄弟节点12345
4.3.4 过滤方法
* $("div p").last(); //取最后一个元素
* $("div p").first(); //取第一个元素
* $("p").eq(1); //去第n个元素
* $("p").filter(".intro"); //过滤,选择所有p标签带有 .intro类
$('p.intro')
* $("p").not(".intro"); //去除,跟上面的filetr正好相反123456
5 DOM与JQuery的转换
(1)、jQuery对象转成DOM对象:[index]和.get(index);
(1)jQuery对象是一个数据对象,可以通过[index]的方法,来得到相应的DOM对象。
如:var $v =$("#v") ; //jQuery对象
var v=$v[0]; //DOM对象
alert(v.checked) //检测这个checkbox是否被选中
(2)jQuery本身提供,通过.get(index)方法,得到相应的DOM对象
如:var $v=$("#v"); //jQuery对象
var v=$v.get(0); //DOM对象
alert(v.checked) //检测这个checkbox是否被选中
(2)、DOM对象转成jQuery对象:
对于已经是一个DOM对象,只需要用$()把DOM对象包装起来,就可以获得一个jQuery对象了。$(DOM对象)
如:varv=document.getElementById("v"); //DOM对象
var$v=$(v); //jQuery对象
转换后,就可以任意使用jQuery的方法了。
通过以上方法,可以任意的相互转换jQuery对象和DOM对象。需要再强调注意的是:DOM对象才能使用DOM中的方法,jQuery对象是不可以用DOM中的方法
下面是其它的相关使用方法:
1、DOM对象转jQuery对象
普通的Dom对象一般可以通过$()转换成jQuery对象。
如:$(document.getElementById("msg"))
返回的就是jQuery对象,可以使用jQuery的方法。
2、jQuery对象转DOM对象
由于jQuery对象本身是一个集合。所以如果jQuery对象要转换为Dom对象则必须取出其中的某一项,一般可通过索引取出。
如: $("#msg")[0],$("div").eq(1)[0],$("div").get()[1],$("td")[5]
这些都是Dom对象,可以使用Dom中的方法,但不能再使用jQuery的方法。
以下几种写法都是正确的:
$("#msg").html();
$("#msg")[0].innerHTML;
$("#msg").eq(0)[0].innerHTML;
$("#msg").get(0).innerHTML;