001 JQuery (001 - 004)

[A] JQuery基础

    JQuery:

      1. 一个快速,简洁的JavaScript框架

                   2. 设计宗旨: "write less, do more"

                   3.  JQuery兼容的主流浏览器,如IE6.0+, FF1.5+, Safari2.0+, Opera9.0+


 

            1. JQuery优点:

                    1. 简化JS的复杂操作

                    2. 不再关心兼容性

            2. JQuery帮助文档

                  官网:https://jquery.com/

            3. JQuery的版本区别:

                  1.0     可以兼容到IE8以下

                  2.0     只兼容IE8以上

                  3.0     目前最新

                  【注】遇到新东西去查文档学

            4. JQuery文件各个版本下载

                    网址:http://www.jq22.com/jquery-info122

            5. JQuery设计思想

                  1. 模拟css选择网页元素

                          【格式】:$("css选择器").css("属性", "属性值")

                      css选择器参考手册: http://www.runoob.com/cssref/css-selectors.html

                  2. 独有表达式选择

                        $("li:first").css("backgroundColor", "red");        第一个li标签

                        $("li:last").css("backgroundColor", "red");         最后一个li标签

                        $("li:even").css("backgroundColor", "red");         偶数位的li标签

                        $("li:odd").css("backgroundColor", "red");          奇数位的li标签

                        $("li:eq(2)").css("backgroundColor", "red");        下标为2的li标签

                  3. 多种筛选方式

                        $("li:eq(2)").css("backgroundColor", "red");        下标为2的li标签

                        或写成:

                            $("li").eq(2).css("backgroundColor", "red");    下标为2的li标签

 

                         $("li.box").css("backgroundColor", "red");          类名为box的li标签

                        或写成:

                            $("li").filter(".box").css("backgroundColor", "red");类名为box的li标签

 

[B] JQuery的写法

                1. 方法函数化

                      示例1:简化页面加载函数

                          $(function(){

                              代码块;

                          })

                          可以替代:

                              window.onload = function(){

                                  代码块;

                              }


                      示例2:简化事件函数

                          $("css样式").onclick = function(){

                              代码块;

                          }

                          可以替代:

                              var oBtn = document.getElementById("id名");

                              oBtn.onclick = function(){

                                  代码块;

                              }

                      【注】在JQ中基本上见不到等于号,所有的复制操作都是函数传参实现的


                2. 链式操作

                      对于同一个目标元素,若有多个事件函数,可以实现链式操作

                      示例:

                          $("#oBtn").onclick = function(){

                              alert("我被点击了");

                          }


                          $("#oBtn").onmouseover = function(){

                              alert("鼠标来了");

                          }


                          $("#oBtn").onmouseout = function(){

                              alert("鼠标离开了");

                          }

                          转化为链式操作:

                              $("#oBtn").onclick = function(){

                                  alert("我被点击了");

                              }.onmouseover = function(){

                                  alert("鼠标来了");

                              }.onmouseout = function(){

                                  alert("鼠标离开了");

                              }

                3. 取值赋值合体

                      即一步实现取值和赋值两步操作

                      示例:获取元素节点内容并赋值

                          $("#div1").html();              

                              // 获取id为div1的节点里的内容,返回值即为内容


                          $("#div1").html("我是替换文本");        

                              // 获取获取id为div1的节点里的内容,并将该内容替换为"我是替换文本"


        【注】JQ与JS的关系

                JQ底层代码是JS,两者可以共存,但是不能混用

                所谓共存,是指语句可以交叉使用

                所谓不能混用,是指一条语句不能同时包含JQ和JQ两种代码

 

[C] JQuery常用方法1

      1. filter   过滤,对已经获取到的网页元素进行过滤

                          示例:

                              $("div").filter(".box").css("width", "100px")

                              // 将选中的div中,把类名为box的元素设置为"width = 100px"

                    2. not      过滤的反义词,即在已经选中的网页元素中去除元素

                          示例:

                              $("div").not(".box").css("width", "100px")

                              // 将选中的div中,把除了类名为box的元素都设置为"width = 100px"

                    3. has      拥有,根据节点的子元素特征,来选择父元素

                          示例:

                              $("div").has(".box").css("width", "100px")

                              // 将选中的div中,把拥有类名为.box的子节点的节点选中

                    4. prev     查找当前兄弟节点中的上一个节点

                     next     查找当前兄弟节点中的下一个节点

                          示例:

                              $("div").prev(".box").css("width", "100px")

                              $("div").next(".box").css("width", "100px")

                    5. find     查找指定条件下的子节点

                          示例:

                              $("div").find("[name=ad]").css("width", "100px")

                    6. index(下标)    获取当前节点在兄弟节点中的下标

                          示例:

                              $("h3").index();            

                                  // 返回值为标签h3在兄弟节点中的下标

                    7. eq(下标)     通过下标获取指定的元素节点

                          示例:

                              $("li").eq(2).css("width", "100px")

                              // 获取下表为2的li标签

                    8. attr         获取和设置行间属性

                          示例:

                              获取行间属性

                                    $("#div").attr("title")

                                        // 返回值为指定节点的title

                              设置/修改行间属性

                                    $(#div).attr("title", "word")

                                        // 将行间属性title修改为"word"

                              一次性修改多个行间属性

                                    $(#div).attr({

                                        title: "word",

                                        class: "xxx"

                                    })

 

[D] JQuery常用方法2

      1.  addClass()       添加class的某个或多个样式

                       removeClass()    删除class的某个或多个样式

                          示例:

                              $("div1").addClass("box2 box3 box4")

                                  添加class样式,若某个被添加的样式已经存在,测忽略

                              $("div1").removeClass("box3 box4")

                                  删除掉某个class样式,若某个样式不存在,则忽略掉

                    2.  获取节点的宽度

                          width()             width

                          innerWidth()        width + padding 

                          outerWidth()        width + padding + border

                          outerWidth(true)    width + padding + border + margin

 

                    3.  获取节点的高度

                          height()             height

                          innerheight()        height + padding 

                          outerheight()        height + padding + border

                          outerheight(true)    height + padding + border + margin

                    4.  节点操作(不用事先创建节点)

                          insertBefore()      before()      将某节点插在节点之前

                              $("span").insertBefore("div")

                              // 将span节点插在div节点之前

                          insertAfter()       after()       将某节点插在节点之后

                              $("span").insertAfter("div")

                              // 将span节点插在div节点之后

                          appendTo()          append()      将某节点接到节点的子节点最后

                               $("span").appendTo("div")

                              // 将span节点插在div节点的子节点后面

                          prependTo()         prepend()     将某节点接到节点的子节点首位

                              $("span").prependTo("div")

                              // 将span节点插在div节点的子节点首位

                          remove()                          删除某节点

                              $("span").remove()

                              // 将span节点删除掉

                          【注】insertBefore()和before()对比

                              1. 同样的效果,表达方式不一样

                                  示例:

                                      $("span").insertBefore("div")

                                          // 将span节点插在div节点之前

                                      等价于:

                                          $("div").before("span")

                                              // 在div节点之前插入节点span

                              2. 链式操作时,主体不一样

                                  示例:

                                      $("span").insertBefore("div").css("backgroundColor", "red")

                                          // 将span节点插在div节点之前,并且span背景色设置为红色

                                      等价于:

                                          $("div").before("span").css("backgroundColor", "red")

                                              // 在div节点之前插入节点span,并且div背景色设置为红色

                    5. on和off

                              1. 传统的事件类型只能绑定一个事件,同时绑定多个事件,则后面会覆盖前面,只有最后一个有效

                              2. 事件监听器可以实现一个事件类型绑定多个事件,但是无法精确的删除其中某一个函数

                          在JQuery中,不带on的事件绑定,其底层使用事件监听器实现的,可以同时绑定多个事件,互不影响

                              如:同时绑定三个事件

                                  $("#div").click(function(){

                                      alert(1);

                                  })

                                  $("#div").click(function(){

                                      alert(2);

                                  })

                                  $("#div").click(function(){

                                      alert(3);

                                  })

                              则可一次点击触发三个事件

                      on方法添加事件

                              1. 给一个事件添加一个函数

                                    $("#div").on("click", function(){

                                        alert(1);

                                    })

                                    // 给div添加click事件

                              2. 给多个事件添加同一个函数,多个事件用冒号隔开即可

                                    $("#div").on("click mouseover", function(){

                                        alert(1);

                                    })

                              3. 给多个事件分别添加不同的函数,传入事件=>函数键值对即可

                                    $("#div").on({

                                        click: function(){

                                            alert(1);

                                        },

                                        mouseup: function(){

                                            alert(2);

                                        },

                                        mousemove: function(){

                                            alert(3);

                                        },

                                    })

                              4. 事件委托

                                      on的参数分别为: 父节点,触发对象的选择器,触发函数

                                    示例: 

                                        $("ul").on("click","li",function(){

                                            $(this).css("backgroundColor", "red");

                                        })

                        off方法取消事件

                              1. 取消所有事件上的所有函数

                                    $("#div1").off()

                              2. 取消某一个事件上的所有函数

                                    $("#div1").off("click")

                              3. 取消某一个事件上的某一个函数

                                    $("#div1").off("click", show)

                                    【注】这个被取消的函数必须是由函数名的函数

              6. 创建节点

                          $(`<li>内容</li>`).append($("ul"));

 

[E] JQuery常用方法3

                    1. 阻止事件冒泡 stopPropagation()

                          示例:

                              $("#div1").on("click", function(ev){

                                  aleret(this.id);

                                  ev.stopPropagation()

                              })

                    2. 阻止对象的默认行为 preventDefault

                          示例:

                              $("a").click(function(ev){

                                  ev.preventDefault();

                              })

                              取消a链接的默认行为,点击后不会跳转

                    3. 既阻止事件冒泡,又阻止默认行为 return false

                          示例:假设a又冒泡事件

                              $("a").click(function(ev){

                                  return false;

                              })

                    4. which

                           1. 在鼠标事件中输出button

                                      输出值:

                                          左键    1

                                          滚轮    2

                                          右键    3

                                  $("#div1").click(function(ev){

                                      alert(ev.which);

                                  })

                         2. 在keydown事件中,输出keyCode     键码(不区分大小写)



                            3. 在keypress事件中,输出charCode   字符码(区分大小写)


                    5.  offset()             直接获取当前元素到可视窗口的距离

                        offset().left       直接得到当前元素到最左端(可视窗口)的距离

                        offset().top        直接得到当前元素到最左端(可视窗口)的距离

                        【注】没有offset().right和offset().bottom

                          示例:

                              $("#div2").offset().left

                                  获取div2节点距离可视窗口最左端的距离

                    6.  position()           直接获取当前元素,距离第一个有定位父节点的距离,margin算在内

                         position().left     

                         position().top

                        【注】没有position().right和position().bottom

                          示例:

                              $("#div2").position().left

                                  获取div2节点距离第一个有定位的父节点最左端的距离

                    7. offsetParent()       查找第一个有定位的父节点,如果父节点没有定位子继续找,最后找到html

                          示例: 

                              $("#div1").offsetParent().css("backgroundColor", "red")

                                  将div1元素的有定位元素的父节点的背景色设置为red。

                    8. val()            获取/设置表单元素的值

                          【注】1. 取值时,JQ只能取到第一个符合条件的元素的值

                                2. 设置时,JQ批量设置所有符合条件的元素的值

                            此外:

                                  css(), arttr(), html()等都可以实现批量赋值

                    9. size()           获取网页元素的个数

                        length           等同于size()

                    10. each()           循环遍历

                        示例:

                            $("div").each(function(item, index){

                                $(item).html(index);

                            })

 

 

posted @ 2020-07-08 16:22  CarreyB  阅读(128)  评论(0编辑  收藏  举报