JQuery知识总结

JQuery基础

  • jquery获取元素的方法:$()
    在 jQuery 中,只有一个全局变量 $,这是 jQuery 的一大特点,避免了全局变量的污染
  • jquery对象:$() 方法获取到的内容叫做 jQuery 对象
  • jQuery 对象中原生 js 对象的个数:
    1.$().length
    2.$().size()
  • 原生对象与jQuery相互转换
    1.jQuery 转原生:直接利用数组下标方式,得到 jQuery 封装的原生对象。
    2.原生转 jQuery:将原生对象用 $() 方法包裹即可

jQuery选择器

  • css2.1和css3选择器
    参数:必须是字符串格式的选择器
  • jQuery筛选选择器
    用法:在基础选择器后面增加一些筛选的单词,筛选出前面选择器的选中内容中一部分。
    常用:$(":first") 第一个
    $(":last") 最后一个
    $(":first") 第一个
    $(":last") 最后一个
    $(":eq(index)") 下标为 index 的项
    $(":gt(index)") 大于下标为 index 的项
    $(":lt(index)") 小于下标为 index 的项
    $(":odd") 下标为奇数的项
    $(":even") 下标为偶数的项
    $(":not(selector)") 去除所有与给定选择器匹配的元素
  • 筛选方法
    常用: $("p").first()
    $("p").last()
    $("p").eq(3)

Jquery常用方法

  • jQuery操作标签内容的方法
  1. html()方法
    html() 方法相当于原生 JS 中的 innerHTML 属性,用来获取或设置标签内部内容。
  • 获取:文本和内部标签 语法:jQuery对象.html();
  • 设置:若设置标签时,标签会被渲染 语法:jQuery对象.html('文本内容');
// html() 方法,如果传递参数,批量更改元素内部的内容
// 如果内部的字符串包含了标签的语法的字符,会按照 html 语法进行加载
$box.html('这是新增加的子级<p>这是段落</p>')
// html() 方法不传递参数,是获取元素内容
// 获取时只能获取第一个元素内部的文案
$box.html() //html语法加载
  1. text()方法
    text() 方法相当于原生 JS 中的 innerText 属性,用来获取或设置标签内部文字。
  • 获取:仅仅是文本 (语法:jQuery对象.text();)
  • 设置:若设置标签时,标签会被当做普通文本 (语法:jQuery对象.text('文本内容');)
// 获取所有的标签内部的文字内容,忽略标签
// 设置,会将书写的内容都当成普通文字,不会按照标签加载
$box.text("普通文本<p>段落</p>") // 会显示标签
  1. val() 方法
    val() 方法相当于原生 JS 中的 value 属性,用来获取或设置表单元素内容
  • 获取:表单元素的 value 语法:jQuery对象.val();
  • 设置:表单元素的value 语法:jQuery对象.val('文本内容')

jQuery 操作标签的属性

  1. attr() 方法:用来获取或者设置标签的属性值
    设置标签的属性:jQuery对象.attr(name,value)
    获取标签属性值:jQuery对象.attr(name)
  2. removeAttr() 方法:移除标签的属性 removeAttr(name)
  3. prop() 方法:针对selected、checked、disabled 等表单元素的属性。此类属性的属性值与属性名相同
    获取:$('input').prop('属性名') 设置:$('input').prop('属性名',值)

jQuery 操作样式方法

  1. css()方法:用于调用 css 属性值或者更改 css 属性值
    语法:jQuery对象.css(name,value)
// css() 传一个参数:获取对应的属性值
$box.css("width")
// css() 传入两个参数:设置或更改对应的属性值
$box.css("width","400px")
// 设置多条属性,可以使用对象形式的参数
 $box.css({
      "width": 200,
      "height": 300
  })

• 一个参数:表示调用 css 属性的值,得到的是某个元素的计算后样式,值为字符串格式。
• 两个参数:表示设置 css 样式属性,第二个参数可以是字符串格式的属性值,如果带单位的数字的
属性值,可以写成带单位的字符串格式、不带单位的字符串、纯数字、带 += 等赋值运算的字符串。
• css() 方法的第一个参数,复合属性的单一属性写法可以是驼峰命名法,也可以是横线写法。
• 可以给同一个对象同时设置多条 css 属性,将多条属性的属性和属性值写成对象格式,传给 css()
的参数

jQuery 操作类名方法

  1. addClass() 添加类名
  2. removeClass() 移除类名
    • 不传参数,表示删除所有的类名
  3. toggleClass() 类名切换
    若这个类名存在,则会移除该类名。否则添加该类名
  4. hasClass() 检测类名是否存在(返回值:true 和 false)
    // 判断一个类名在标签中是否加载
        console.log($box.hasClass("demo"))
        // 模拟一下 切换 类名的效果
        $btn3.click(function () {
          // 判断 box 是否有 demo 的类名
          if ($box.hasClass("demo")) {
            // 如果有 demo,就删除
            $box.removeClass("demo")
          } else {
            // 如果没有 demo,就添加一个
            $box.addClass("demo")
          }
        })

jQuery 常用事件方法

  1. click() 方法:点击事件
  2. mouseenter() 方法:鼠标进入一个元素触发的事件
  3. mouseleave() 方法:鼠标离开一个元素触发的事件

注意:mouseenter 和 mouseleave 没有事件冒泡。
在使用时替换 mouseover 和 mouseout 更加合适

  1. hover() 方法:hover 事件相当于将 mouseoenter 和 mouseleave 事件进行了合写
    参数:有两个参数,第一个参数是鼠标移上执行的事件函数,第二个参数是鼠标离开执行
    事件函数。
 // hover() 方法,对mouseenter 和 mouseleave 进行了合并书写
        $box.hover(function () {
          // 鼠标移入
          $box.addClass("demo")
        },function () {
          // 鼠标离开
          $box.removeClass("demo")
        })

jQuery 关系查找方法

  1. $(this) 自己的jQuery 对象
    在 jQuery 中将 this 关键字传递给 $() 方法,得到就是指向自己的 jQuery 对象,就可以使用 JQ 的方法
  2. parent() 父级
    jQuery 对象都有一个 parent() 方法,得到的是自己的父亲级
  3. children() 子级
    jQuery 对象内部有一个 children() 方法,可以得到自己的所有子级元素组成的 jQuery对象
  4. siblings() 兄弟
    jQuery 对象通过调用 siblings() 方法可以得到除了自己以外所有同级元素(兄弟)组成 jQuery 对象,找到的只能是亲的兄弟,不能是叔叔家的兄弟

链式调用

  1. jQuery 对象调用任何方法(除了节点关系方法)执行完后,方法都会有一个返回值,返回
    值就是 jQuery 对象自己,这个现象给我们提供了便利,可以对执行结果继续打点调用 JQ
    的方法和属性。
  2. 可以使用 jQuery 对象进行连续打点调用
    // 获取所有的 p 标签
    var $ps = $("p")
    var $box = $(".box")

    // 批量添加事件
    $ps.click(function () {
      // 让点击的自己 颜色变红色
      // jQuery 对象调用除了节点关系的方法之外,其他的方法执行后,返回值就是 对象自己
      // 可以继续链式调用其他的 jQuery 对象的方法和属性
      // 好处:简化代码书写
      // console.log($(this).css("background-color","red").html("哈哈"))
      $(this).css("background-color", "red")        // 自己变红色
      .siblings().css("background-color", "gold")   // 兄弟变金色
      .parent().css("background-color", "pink")     // 父级变粉色
      .siblings().css("background-color", "blue")   // 父级的兄弟变蓝色
      .children().css("background-color", "yellowgreen")  // 父级的兄弟的子级变黄绿色

    })

jQuery 其他关系查找方法

  1. find() 后代元素
    • jQuery 对象可以利用 find() 方法,传递一个参数,参数部分规定的选择器,查范围是jQuery 对象的所有后代。
    • 参数是字符串格式的选择器。
  2. 兄弟元素
    next() 下一个兄弟
    prev() 上一个兄弟
    nextAll() 后面所有兄弟
    prevAll() 前面所有兄弟
  3. parents() 祖先级
    parents() 查找包含body在内的祖先级

Jquery排序和动画

jQuery 排序和方法

  1. eq() 方法(大排序)
  • jQuery 中获得的对象,内部包含选择的一组原生 js 对象,在 jQuery 对象中会进行一个大的排序,这个排序与原来的 HTML 结构没有关系
  • eq() 方法在 jQuery 对象中通过下标获取某个对象,下标是 jQuery 对象中的大的排序的下标
  1. index() 方法(在兄弟中的排序)
    得到的是它自己在 HTML 结构中的兄弟中的下标位置。与jQuery 大排序没有关系。
  2. 排他思想:在一些事件中,希望自己是特殊的,而它的兄弟们是默认的
  • 排它方法:jQuery 中可以让 this 特殊设置,让兄弟 siblings 设置成默认
    -自己的级别的排他:给自己this添加 current 类名,让其他的兄弟删除 current 类。
  • 对应的部分的排他:给对应位置的元素添加 current,其他的兄弟删除 current 类。
  • 找对应关系,使用的是自己的 index() 下标,让另一组中下标相同的项作为对应项。
  • 通过选中另一组的对应项利用 eq() 方法选择下标项
       // 获取所有的 span
        var $span = $(".tab .title span");
        // 添加鼠标移上事件
        $span.mouseenter(function () {
            // 利用变量存储 this 的下标
            var idx = $(this).index();
            // 自己级别的排他
            $(this).addClass("current").siblings().removeClass("current");
            // 对应级别的排他
            $(".tab .detail ul").eq(idx).addClass("current").siblings().removeClass("current");
        })

• 以上方式在一个 tab 栏效果中没有问题。
• 在一个网页中,可能会出现多个相同 tab 栏结构,只有第一个 tab 栏中的列表项会进行
切换

  1. Tab 栏优化
<script>
       // 获取所有的 span
       var $span = $(".tab .title span");
       // 添加鼠标移上事件
       $span.mouseenter(function () {
           // 利用变量存储 this 的下标
           var idx = $(this).index();
     // 自己级别的排他
     // 查找所有对应 ul 时候,不要单独选择所有 ul,要通过当前的 this 的节点关系查找
     // 链式调用方式,找到自己父级中的兄弟中的所有子级 ul
     $(this).addClass("current")
     .siblings().removeClass("current")
     .parent().siblings().children().eq(idx).addClass("current")
     .siblings().removeClass("current");
           
       })
   </script>

解决方法:span 和 ul 的查找全部使用链式调用,通过节点关系查找

  1. each() 遍历
  • each()方法
    参数是一个函数。
    作用:就是对 jQuery 对象中的元素每一个都执行函数内部的操作。
    each 方法的基本原理就是 for 循环,从对象的下标为 0的项一直遍历到最后一项,然后对每一项进行操作

1.each 的函数内部,也有一个 this,指向的是进来遍历的每一次的元素
2.each 的函数可以传一个参数 i,i 表示的是这一次的遍历对象在整体的 jQuery 对象大排队中的下标位置

jQuery 中的入口函数

  1. 原生的 window.onload
  2. jQuery 中的入口函数
  • 语法1:
    $(document).ready(function(){
    // 获取元素
    });
  • 语法2:
    $(function(){
    // 获取元素
    });

• onload 事件,等待所有的页面中的资源(DOM树、图片、视频、音频等外部资源)加载完毕之后,才会执行
• jq 的入口函数,仅仅需要等待 DOM 树加载完成就立即执行

jQuery 切换效果方法

  1. 显示隐藏方法
    hide():元素隐藏,隐藏的前提必须是元素 display:block;
    show():元素显示,显示的前提必须是元素 display:none;
    toggle():在元素隐藏和显示之间进行切换。
  • 如果不传参数:直接显示和隐藏,没有过渡动画
  • 如果传递参数:
    1. 单词格式:"slow","normal", "fast"
    2. 数字格式的时间,单位是毫秒,在规定时间之内会出现显示或隐藏的动画

• 这三个方法可以设置元素的显示和隐藏效果,在过程中还可以出现过渡动画。

  1. 滑动显示隐藏
    slideDown():滑动显示(方向不一定)
    slideUp():滑动隐藏
    slideToggle():滑动切换
    让元素在 display 属性的 block 和 none 之间进行切换
  • 如果不传参数:默认的过渡时间为 400 毫秒。
  • 如果传递参数
    1. 单词格式:"slow","normal", "fast"
    2. 数字格式的时间,单位是毫秒,在规定时间之内会出现显示或隐藏的动画。

• 如果滑动的元素没有设置宽高,没有滑动效果。
• 如果元素设置了高度和宽度,会进行上下垂直方向的滑动。
• 动画的效果:高度属性在 0 到设置值之间的变化,没有透明度动画。
• 如果元素设置了定位,偏移量方向如果是 bottom 参与了,滑动方向会发生变化。

  1. 淡入淡出
    fadeIn():淡入,透明度逐渐增大最终显示。
    fadeOut():淡出,透明度逐渐降低最终隐藏。
    fadeToggle():切换效果。
    adeTo():淡入或淡出到某个指定的透明度。
    动画效果,执行的是透明度动画。也是在 display 属性的 block 和 none 之间切换
  • 如果不传参数:默认的过渡时间为 400 毫秒。
  • 如果传递参数
    1. 单词格式:"slow","normal", "fast"
    2. 数字格式的时间,单位是毫秒,在规定时间之内会出现显示或隐藏的动画

animate() 动画方法

  1. animate()方法
    • 语法:$(selector).animate(styles,speed,easing,callback)
    • 参数1: css 的属性名和运动结束位置的属性值的集合。
    • 参数2:可选,规定动画的速度,默认是 "normal"。其他值,“slow”、“normal”、“fast”,数字格式,单位为毫秒
    参数3:可选,规定在不同的动画点中设置动画速度的 easing 函数,值包含 swing 和 linear
    • 参数4:可选,animate 函数执行完之后,要执行的函数
    • 注意:其他的运动方法比如 slideUp() 等,也有参数3 和参数4
$(this).animate({"left": 500},during,"swing",function () {
   // 在运动结束后,让元素变红色
  $(this).css("background","red")
})
  1. 动画排队
  • ①同一个元素对象身上,如果定义了多个动画,动画会排队等待执行。
// 排队执行下面动画代码
$box1.animate({"left": 400,"top": 400},during)
$box1.animate({"left": 400},during)
$box1.animate({"top": 400},during)
$box1.animate({"left": 0},during)
$box1.animate({"top": 0},during)
$box2.animate({"top": 400},during)

• ②如果是不同的元素对象都有动画,不会出现排队机制。

//不需要排队,同时执行动画代码
$box1.animate({"top": 0},during)
$box2.animate({"top": 400},during)

• ③非运动的代码,关于同一个元素对象的,也不会排队

$box1.css("height",100)

• ④之前学习的自带动画的显示隐藏方法,如果设置给同一个元素,也有动画排队。

$box1.mouseenter(function () {
      $(this).children().slideUp(during)
})
 $box1.mouseleave(function () {
      $(this).children().slideDown(during)
})

• 同一个元素身上的多个运动,可以简化成链式调用的方法。

$box1.children().fadeOut(500).fadeIn(500).fadeOut(500).fadeIn(500)

delay() 延迟方法

  1. 动画延迟
    • 将 delay() 设置在某个运动方法之前,表示后面的运动要在规定的时间之后再执行,有延迟运动的效果。
    • 参数:时间的数值,表示延迟的时间。
    • 除了 animate 方法之外,其他的运动方法也有延迟效果
// 延迟
$box1.animate({"left": 500},during);
$box2.delay(2000).animate({"left": 500},during);
  1. stop() 停止动画方法
    • stop() 作用:设置元素对象身上的排队的动画以何种方式进行停止。
    • 有两个参数,都是布尔值。
    • 参数1:设置是否清空后面的动画排队,如果是 true 表示清空,如果是 false 表示不清空只停止当前的一个动画。
    • 参数2:设置当前动画是否立即完成,如果是 true 表示立即完成,对象会立刻走到结束位置,如果是 false 表示不完成当前动画,立即停止在当前位置。
    • 默认情况下,两个参数值默认值为 false。
    • 根据两个参数的值,可以得到四种停止方式
        // box1 有四个运动进行排队
        $box1.animate({"left" : 500},during);
        $box1.animate({"top" : 500},during);
        $box1.animate({"left" : 0},during);
        $box1.animate({"top" : 30},during);

        // 添加按钮点击事件
        // 清空动画,走到结尾
        $("#btn1").click(function () {
            $box1.stop(true,true)
        })

        // 清空动画,停在当前
        $("#btn2").click(function () {
            $box1.stop(true,false)
        })

        // 不清空后面的动画,当前运动立即走到结尾
        $("#btn3").click(function () {
            $box1.stop(false,true)
        })

        // 不清空后面的动画,当前运动立即停止在当前位置
        $("#btn4").click(function () {
            $box1.stop(false,false)
        })

在实际工作中,一般要求会清空后面的动画,当前动画要停止在当前的位置
更多时候使用 stop(true),,第二个参数不设置默认为 false

  1. 清空动画排队
  • 动画排队问题
    • 如果将开启运动的程序放在一个事件函数中,事件多次被触发,会执行多次函数,就会在一个元素身上添加了多个动画,会进行动画排队。
    • 需要去清除排队的动画,进行防骚扰操作
  • 解决方案一:
    • 利用 stop() 方法。
    • 在每一个运动函数之前都增加一个 stop(true),表示在运动执行之前,会将前面排队的动
    画清空,然后停止在当前位置。
$box1.mouseenter(function () {
    $(this).children().stop(true).slideUp(during)
})
$box1.mouseleave(function () {
    $(this).children().stop(true).slideDown(during)
})
  • 解决方案二:
    • 利用函数节流方法,如果元素在运动,直接 return,不要执行后面的运动代码。
    • 每个 jQuery 对象,都能调用一个 is() 方法,作用是显示元素对象的某种状态。
    • 如果参数位置是 is(“:animated”),返回值是布尔值,true 表示正在运动,false 表示
    没有运动
// 清空动画排队方法2:使用函数节流方式
$box1.mouseenter(function () {
    // 判断元素自己是否在运动中,如果是,那么直接返回不要往下添加新的运动
    if ($(this).children().is(":animated")) {
        return;
    }
    // 如果走到这里,说明元素没有在运动,就可以添加新运动
    $(this).children().stop(true).slideUp(during)
})
$box1.mouseleave(function () {
    // 判断元素自己是否在运动中,如果是,那么直接返回不要往下添加新的运动
    if ($(this).children().is(":animated")) {
        return;
    }
    $(this).children().stop(true).slideDown(during)
})
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容