jQuery 知识点总结

【文章根据 尚硅谷 教学材料 总结】

发博备查。

1.    
    . class选择器
    # id选择器
    : 选取

2. $(function(){})相当于 window.onload 方法.
    window.onload = function(){...}
    
3. 加载DOM的两种方式: jQuery 和 window.onload
    $(document).ready(function(){...})
    $(function(){...}

4. 选取button 并添加 onClick 响应函数. $("button").click(function(){}

5. jQuery 和 DOM 对象
    [1]. 由 jQuery 对象转为 DOM 对象.
        1). 获取一个 jQuery 对象.
            var $btn = $("button");
        2). jQuery 对象是一个数组.
            alert($btn.length);
        3). 可以通过数组下标转为 DOM 对象.
            alert($btn[1].firstChild.nodeValue);
    [2]. 由 DOM 对象转为 jQuery 对象.
        1). 选取一个 DOM 对象.
            var btn = document.getElementById("btn");
        2). 把 DOM 对象转为一个 jQuery 对象:使用 $() 进行包装.
            alert($(btn).text());

6. 使用 id 选择器选择 id=btn1 的元素, 并为选择的 jQuery 对象添加 onclick 响应函数.
        $("#btn1").click(function(){...});

7. jQuery 对象遍历的方式是 each , 在 each 内部的 this 是得到的 DOM 对象, 而不是一个jQuery 对象
    $("#btn5").click(function(){
        var leng = $(":checkbox[name=‘newsletter‘:checked]").each(function(){
            alert(this.value);
        });
    });

8. 选取子元素需要在选择器前添加空格.  div.one 同 .one .
        $(".one :nth-child(2)").css("backgroud" ,"#ffbbaa");

9. 选择的是一个数组, 当该数组中有多个元素时, 通过 .val() 方法就只能获取第一个被选中第一个被选中的值了.

10. jQuery 对象可以进行隐式迭代:
        $("p").click(function(){...})
    为选取的所有的 p 节点都添加了 click 响应函数.
    jQuery 对象本身就是一个 DOM 对象的数组.
            
11. 在响应函数中, this 是一个 DOM 对象, 若想使用jQuery 对象的方法, 需要把其包装为 jQuery 对象:
    使用 $() 把 this 包起来.
            
12. text() 方法是一个读写的方法:
    不加任何参数, 读取文本值;
    加参数, 为属性节点添加文本值(文本节点).
    和 text() 方法类似的:attr() ,val().

13. 使用 jQuery 操作文本节点, 属性节点 及查找元素节点.
    1). 操作文本节点:通过 jQuery 对象的 text() 方法
        alert($("#bj").text());
        $("#bj").text("TEST");
        
    2). 操作属性节点:通过 jQuery 对象的 atter() 方法.
        注:直接操作 value 属性值可以使用共便捷的 val() 方法.
        alert($(":text[name=‘username‘]").attr("value"));
        $(":text[name=‘username‘]").attr("value","TEST");

14. 创建节点:
        使用 $(html) 方式即可, 元素节点, 文本节点, 属性节点可以一网打尽返回对应节点的 jQuery 对象 :
            $("<li id=‘TEST‘>测试</li>")
            
15. 添加节点:
        1). appendTo() 和 append():主语和宾语的位置不同:
                ("<li id=‘TEST‘>测试</li>").appendTo($("#city"));
                $("#city").append("<li id=‘TEST‘>测试</li>");
                
        2). prependTo() 和 prepend():主语和宾语位置不同:
                $("<li id=‘TEST‘>测试</li>").prependTo($("#city"));
                $("#city").prepend("<li id=‘TEST‘>测试</li>");

16. 同 JS 的响应函数一样, jQuery 对象的响应函数若返回 false 可以取消指定元素的默认行为,比如 submit , a 等.
        
17. val() 方法,相当于 attr("value"),获取表单元素的 value 属性值

18. $.trim(str) 可以去除 str 的前后空格.

19. jQuery 对象的 remove() 方法:
        将把jQuery 对象对应的DOM节点直接删除
            $("#bj").remove();

20. 清空 game 节点:
        jQuery 对象的 empty() 方法: 清空jQuery对象对应的 DOM 对象的所有的子节点.
            $("#game").empty();

21. jQuery 调用jQuery 提供的方法的返回值如果是一个对象的话那么这个对象一定是一个 jQuery 对象

22. find() 方法:查找子节点,返回值为子节点对应的 jQuery 对象.

23. jQuery clone 方法:复制节点.
    1). clone 节点时需要注意克隆后的节点的 id 属性.若原节点有 id 属性, 则克隆后,会在一个文档中出现两个相同 id 的节点的情况.
            
    2). clone(true):在克隆节点的同时,克隆节点包含的事件.
            
24. jQuery replaceWith (replaceAll) 方法:替换节点.
        1). repalceWith ,replaceAll 一对方法完成相同功能,只是主宾位置不同.
        2). 以上的两个方法还有移动的功能.
        3). 节点互换需要先克隆节点.
        4). var $rl = $("rl").replaceWith($bj2);  返回的是被替换的节点 rl .

25.
    1). 创建一个<li>测试</li> 节点,替换 #city 的最后一个 li 子节点.
            $("<li>测试</li>").repalceAll($("#citi li:last"));
    2). 创建一个<li>测试</li> 节点,替换 #city 的第二个 li 子节点.
            $("#city li:eq(1)").replaceWith($("<li>测试</li>"));
    3). 互换以下两个节点: #rl 和 #bj .(互换节点有移动的功能).
            var $bj2 = $("#bj").clone(true);
            var $rl = $("rl").replaceWith($bj2);
            $("#bj").replaceWith($rl);

26. 使用 jQuery wrap ,wrapAll ,wrapInner:
        1). 包装 li 本身.
            #("#game li").wrap("<font color=‘red‘></font>");
        2). 包装所有 li .
            $("#city li").wrapAll("<font color=‘red‘></font>");
        3). 包装 li 里边的文字.
            $("#language li").wrapInner("<font color=‘red‘></font>");

27. val 不能直接获取 checkbox 被选择的值.若直接获取, 只能得到第一个被选择的值.
    因为 $(":checkbox[name=‘c‘]:checked") 得到的是一个数组, 而使用val()方法只能获取数组元素的第一个值, 若希望打印被选择的所有值, 需使用 each 遍历

28. jQuery 样式相关的方法.
        1). hasClass():某元素是否有指定的样式.
                alert($("div").hasClass("SubCategoryBox"));//true
        2). 移除样式.
                $("div").removeClass("SubCategoryBox");
        3). 添加样式.
                $("div").addClass("SubCategoryBox");
        4). 切换样式:存在则去除;没有则添加.
                $(".showmore").click(function(){
                    $("div:first").toggleClass("SubCategoryBox");
                    return false;
                });
        5). 获取和设置元素透明度: opacity 属性.
                alert($("div:first").css("opacity"));
                $("div:first").css("opacity".0.5);
        6). width() & height() .
                alert($("div:first").width());
                alert($("div:first").height());
                $("div:first").width(400);
                $("div:first").height(80);
        7). 获取元素在当前视窗中的相对位移:offset() .
            其返回对象包含了两个属性: top ,left .该方法只对可见元素有效.
                alert($("div:first").offset().top);
                alert($("div:first").offset().left);

29. onclick 事件的另一种写法: bind: 为某 jQuery 对象绑定事件.
        $(".head").click(function(){...});
        $(".head").bind("click" ,function(){...})

30. 事件冒泡:什么是事件的冒泡.
        $("body").click(function(){
            alert("1");
        });
        
        $("#content").click(function(){
            alert("2");
        });
        
        $("span").click(function(){
            alert("3");
            //如何解决事件冒泡:通过在响应函数的结尾返回 false ,可以阻止冒泡.
            return false;
        });

31. toggle() 可以切换元素是否可见.
    slideToggle():通过高度变化来切换匹配元素的可见性.
    fadeToggle():通过透明度变化来切换匹配元素的可见性.
    fadeTo():把不透明度以渐进的方式调整为透明的值.

32. var $category = $("li:gt(5):lt(7)");
    此时的lt 是在 li:gt(5) 基础上运行的.

33. 总结:
    [1]. jQuery 是 JavaScript 的一个函数库,非常方便,非常主流
    [2]. 利用 jQuery 开发的步骤:
        1). 导入 jQuery 库
        2). 在 $(function(){}) 中编辑代码
    [3]. jQuery 对象 vs DOM 对象
        1). 两者不能使用对方的属性和方法
        2). jQuery 对象是一个 DOM 数组对象, 所以可以使用下标的方式转为DOM对象.
            var $btn = $("button");
            var btn = $btn[0];
        3). jQuery 对象是使用 $() 包装 DOM 对象后产生的对象。
            $("select :selected").each(function(){
                alert($(this).value);
            })
    [4]. jQuery 的选择器。
        1). 选取被选中的 select 的 option 需要使用选取子节点的方式
            $("select[name=‘test‘] :selected").each(funtion(){...})
        2). jQuery 选择器可以综合使用
        3). 如果选择器搞不定,可以调用方法实现
    [5]. jQuery 对象的几个方法:
        1). val():获取或设置表单元素的 value 属性值
            设置值
                $(":text:enable").val("TEST");
            获取值
                $(":text:enable".val())
        2).attr(): 和val()方法类似
            attr(name.val):为 name 属性赋值为 val
            attr(name):获取 name 属性值
        3).each():对 jQuery 对象进行遍历,其参数为 function, 函数内部的 this 是正在遍历的 DOM 对象
            $("select :selected").each(function(){
                alert(this.val);
            })
        4).text():和 val() 方法类似
            text():获取元素节点的文本子节点的值
            text(str):设置元素节点的文本子节点的值

[6].使用jQuery进行DOM操作:
        1).新建(元素、属性、文本)节点:直接使用$()包装即可,返回值是一个jQuery对象。
            var $TEST = $("<li id=‘TEST‘>测试</li>");
        2).节点插入到文档中:
            ① append ,appendTo:把节点 A 插入为节点 B 的最后一个子节点

$("<li id=‘TEST‘>测试</li>").appendTo($("#city"));
                $("#city").append("<li id=‘TEST‘>测试</li>");

② prepend ,prepenfTo

$("<li id=‘TEST‘>测试</li>").prependTo($("#city"));
                $("#city").prepend("<li id=‘TEST‘>测试</li>");

③ before ,insertBefore

$("<li id=‘DDD‘>屌屌的</li>").insertBefore($("#bj"));
                $("#bj").before("<li id=‘DDD‘>屌屌的</li>");

④ after ,insertAfter

$("<li id=‘DDD‘>屌屌的</li>").insertAfter($("#bj"));
                $("#bj").after("<li id=‘DDD‘>屌屌的</li>");

3).删除节点:

$("#bj").remove();

4).清空节点:

$("#game").empty();

5).克隆节点:

$("#bj").clone(true);

6).替换节点:

$("<li>测试</li>").repalceAll($("#citi li:last"));
        
            $("#city li:eq(1)").replaceWith($("<li>测试</li>"));

7).wrap ,wrapAll ,wrapInner:了解

8).val() ,html() ,text() ,attr() ,width() ,height() 等兼具有读写功能的方法.

//读取某个节点的html内容
            alert($("#city").html());
            
            //设置某个节点的html内容
            $("#city").html("<li id=‘DDD‘>屌屌的</li>")

[7].技术点之外:

1). jQuery 对象可以进行隐式迭代: $("p").click(function(){...})为选取的所有的 p
        节点都添加了 click 响应函数. jQuery 对象本身就是一个DOM对象的数组.
        
        2). 在jQuery 中显示迭代:使用 each() 方法:
            $(":checkbox[name=‘c‘]:checked").each(function(){
                alert(this.value);
            });

可以在显示迭代的响应函数的参数中通过index属性获取到正在遍历的对象的索引.

3).在响应函数中, this 是一个 DOM对象,若想使用jQuery对象的方法,需要把其包装为
        jQuery对象:使用 $() 把 this 包起来.
            
        4). defaultValue :DOM 对象的属性,可以获取表单元素的默认值.

5).通过 val() 为 radio 赋值:即便是为一组 radio 赋值,val参数中也应该使用数组,
        使用一个值不起作用

6).val 不能直接获取 checkbox 被选择的值.若直接获取,只能得到第一个被选择的值.因
        为 $(":checkbox[name=‘c‘]:checked")得到的是一个数组,而使用val()方法只能获取数组元素的第一个值,若希望打印被选择的所有值,需使用 each 遍历.
        而 radio 被选择的只有一个,所以可以直接使用 val() 方法获取被选择的值.

7).1. 同 JS 的响应函数一样, jQuery 对象的响应函数若返回 false 可以取消指定元素
        的默认行为,比如 submit , a 等.
        
        8). $.trim(str) 可以去除 str 的前后空格.

9).jQuery 对象的方法的连缀:调用一个方法的返回值还是调用的对象,于是可以在调用方法的后面依
        然调用先前那个对象的其他方法.

10).find()方法:查找子节点,返回值为子节点对应的jQuery对象.

var $trNode = $(aNode).parent().parent();
            //获取 $tr 的第一个 td 节点的文本节点的文本值.
            var textContent = $trNode.find("tr:first").text();

时间: 2024-11-05 19:38:21

jQuery 知识点总结的相关文章

jquery知识点梳理

jQuery知识点梳理 一.              jquery选择器 基本选择器 ID选择器 类选择器 标记选择器 分组选择器 通配符选择器 层次选择器 $(“ancestor descendent”):祖先后代选择器    空格 $(“parent > child”):父子选择器   大于 $(“prev + next”):相邻后兄弟元素选择器   加号 $(“prev ~ siblings”):所有后兄弟元素选择器  波浪线 过滤选择器:基本过滤选择器 :first.:last.:od

jQuery知识点总结(第一天)

整理笔记前的题外话: 我认为互联网的高速发展其中最为主要的一点就是——开源. 开源精神,使得无数的IT爱好者贡献所学,将自己的智慧结晶无偿奉献给大家.后辈的学习者在混沌的互联网世界里,追寻着前辈们留下的足迹,亦步亦趋的前往更高的层楼.开源精神,大大减少了后辈们在学习技术的难度,使得技术的升级和迭代日新月异.我希望成为一名思维开阔的人,成为对互联网有贡献的开源人. 我是后端PHP程序员,很少写前端页面.在做项目的过程中,被jQuery的便捷性所吸引.因此购买了<锋利的JQuery>一书,最近一边

jQuery知识点总结(第二天)

今天继续从我的笔记上面搬运.我们不产生知识,只是知识的搬运工. 内容过滤选择器: ○ 内容选择过滤器                                       $("div:contains('text')");   内容为'text'的那个div ○ 不包含子元素也不包含文本元素(一穷二白的选择器)   $("div:empty"); ○ 含有选择器所匹配元素的元素(真他妈绕口)              $("div:has(p)&q

jQuery知识点总结

一.元素的增删改查 1.增加 a.append() 和 appendTo()  区别 append():后边的加到前边的里边(后置插入) appendTo():前边的加到后边的里边 b.prepend()  和 prependTo() 区别 后边的加到前边的里边(前置插入) c.after()   和 before() 区别 后边的插入到前边的之后 后边的插入到前边的之前 2.删除 a.remove .empty 和 detach 方法的区别 Remove:移除 Empty:把元素内容清空 De

几个简单的jquery知识点练习

三.jquery对象和dom对象 <script type="text/javascript"> //页面的基本元素加载后 $(function () { var btnObjDom = document.getElementById('btn'); //dom对象变成jquery对象 alert($(btnObjDom).val());//如果val()该方法括号中什么都不写,表示的是获取值 //如果在括号中写内容了,表示的是设置该属性的值 //jquery对象变成dom

jQuery知识点积累

1.  jQuery对象与JavaScript对象转换 jQuery-->JavaScript 两种方法: $(selector).get(index) ;   $(selector)[index]; JavaScript-->jQuery 只需要将获取的JavaScript对象用$包装即可, 如: var obj = document.links;  $(obj).css("color","red");

jquery知识点复习

一. 基本概念 jQuery简介 jQuery是一个基于javascript的框架.它提供了丰富的选择器和大量的函数,可以方便的实现网页中各种动态的效果.迄今为止,已经有大量的jquery插件和基于jQuery的UI框架(miniui.easyui.ligerui). jQuery的宗旨是:write less,do more! 文档加载完毕函数 常规形式:$(document).ready(function(){- -}); 简写形式:$(function(){- -}); jquery对象和

jquery知识点整理

1.jquery可以加载多个ready函数,而原始的js只能加载一次onload 2.用dom对象得到的对象不能使用jquery中的方法,比如var p=document.getElementById("id"),此时p不能这样使用p.html(),而应该使用innerHTML.同样,jquery对象不能使用dom中的方法,如果juqery中改写了dom中的方法,则可以使用dom中的方法. 3.jquery对象转换为dom对象的方法: 4.<input type="te

jQuery知识点总结(第四天)

前三天是jQuery的基础部分,选择器学好了.才能进行下一步的操作,如果前三天没学过没学好,不要跳着学.粗俗的话叫做,步子大了,容易扯着蛋.一步一个脚印,是最好的方式. 强调一下.有问题,不要憋着不讲.评论区里可以尽情提问,有问题才是好孩子. jQuery插入节点的方法: 插入节点主要有两种方式,一种是内插,一种是外插.外插花样多,还分前插和后插.各位看官自动脑补岛国动画,只要你能记住,我拦不住您瞎想. 本着no picture no bibi 的精神.我画几个图,对比学习.当然更好的是你自己练