jQuery

jQuery介绍

1.jQuery是一个轻量级的、兼容多浏览器的JavaScript库

2.jquery使用用户能够更方便地处理HTML Document、Events、实现动画效果、方便地进行Ajax交互,能够极大地简化JavaScript编程。它地宗旨就是:“Write less, do more.“

jquery对象

jquery对象就是通过jquery包装DOM对象后产生的对象。jquery独有的。如果一个对象是jquery对象,那么它就可以使用jquery里的方法:例如$("#i1").html()。

$("#i1").html()的意思就是:获取id为i1的元素的html代码。其中html()是jquery里的方法。

相当于:document.getElementById("i1").innerHTML;

虽然jquery对象是包装DOM对象后产生的,但是jquery对象无法使用DOM对象的任何方法,同理DOM对象也不能使用jQuery里的方法。

一个约定,我们在声明一个jQuery对象变量的时候在变量名前面加上$:

var $varibale = jQuery对象
var variable = DOM对象
$variable[0]//jQuery对象转成DOM对象

拿上面那个例子举例,jQuery对象和DOM对象的使用:

$("#i1").html();//jQuery对象可以使用jQuery的方法
$("#i1")[0].innerHTML;//DOM对象使用DOM的方法

jQuery基础语法

$(selector).action()

查找标签

基本选择器

id选择器:

$("#id")

标签选择器:

$("tagName")

class选择器:

$(".className")

配合使用:

$("div.c1")//找到有c1 class类的div标签

所有元素选择器:

$("*")

组合选择器:

$("#id, .className, tagName")

底层选择器

x和y可以为任意选择器

$("x y");//x的所有后代y(子子孙孙)
$("x>y");//x的所有儿子y(儿子)
$("x+y");//找到所有紧挨在x后面的y
$("x~y");//x之后所有的兄弟y

基本筛选器

:first //第一个
:last //最后一个
:eq(index)//索引等于index的那个元素
:even//匹配所有索引值为偶数的元素,从0开始计数
:odd//匹配所有索引值为奇数的元素,从0开始计数
:gt(index)//匹配所有大于给定索引值的元素
:lt(index)//匹配所有小于给定索引值的元素
:not(元素选择器)//移除所有满足not条件的标签
:has(元素选择器)//选取所有包含一个或多个标签在其内的标签(指的是从后代元素找)

例子:

$("div:has(h1)")//找到所有后代中有h1标签的div标签
$("div:has(.c1)")//找到所有后代中有c1样式类的div标签
$("li:not(.c1)")//找到所有不包含c1样式类的li标签
$("li:not(:has(a))")//找到所有后代中不含a标签的li标签

练习:

自定义模态框,使用jQuery实现弹出和隐藏功能。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="jQuery-3.3.3.js"></script>
    <style>
        .hidden {
            display: none;
        }

        .cover {
            position: fixed;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0;
            background-color: darkgray;
            z-index: 999;
        }

        .modal {
            height: 400px;
            width: 400px;
            background-color: white;
            position: fixed;
            top: 50%;
            left: 50%;
            margin-top: -200px;
            margin-left: -200px;
            z-index: 1000;
        }
    </style>
</head>
<body>
<button id="d1">点击</button>
<div class="hidden cover"></div>
<div class="hidden modal">
    username:<input type="text">
    <br>
    password:<input type="password">
    <br>
    <button id="d2">取消</button>
</div>

<script>
    let b1Ele = $('#d1')[0];
    let $coverEle = $('.cover');
    let $modalEle = $('.modal');
    let b2Ele = $('#d2')[0];
    b1Ele.onclick = function () {
        $coverEle.removeClass('hidden');
        $modalEle.removeClass('hidden');
    };
    b2Ele.onclick = function () {
        $coverEle.addClass('hidden');
        $modalEle.addClass('hidden');

    };
</script>

</body>
</html>
模态框

属性选择器

[attribute]
[attribute=values]//属性等于
[attribute!=value]//属性不等于

例子:

<input type='text'>
<input type='password'>
<input type='checkbox'>
$("input[type='checkbox']");//取得checkbox类型的input标签
$("input[type!='text']");//取得类型不是text的input标签

表单筛选器

:text
:password
:file

:radio
:checkbox

:submit
:reset
:button

例子:

$(":checkbox");//找到所有的checkbox

表单对象属性:

:enabled
:disabled
:checked
:selected

例子:

  找到可用的input标签

<form>
    <input  name="email" disabled="disabled">
    <input  name="id">
</form>
$("input:enabled");//找到可用的input标签

  找到被选择中的option

<select id="s1">
    <option value="beijing">北京市</option>
    <option value="shanghai">上海市</option>
    <option value="guangzhou" selected="">广州市</option>>
    <option value="shenzhen">深圳市</option>>
</select>
$(":selected")//找到所有被选中的option

筛选器方法

下一个元素:

$("#id").next()//下一个元素
$("#id").nextAll()//下面所有元素
$("#id").nextUntil('#i2')//下面到#i2的元素(不包括#i2)

上一个元素:

$("#id").prev()//上一个元素
$("#id").prevAll()//上面所有元素
$("#id").prevUntil("#i2")//上面到#i2的元素(不包括#i2)

父亲元素:

$("#id").parent()
$("#id").parents()  // 查找当前元素的所有的父辈元素
$("#id").parentsUntil() // 查找当前元素的所有的父辈元素,直到遇到匹配的那个元素为止。

儿子和兄弟元素

$("#id").children();// 儿子们
$("#id").siblings();// 兄弟们

查找

  搜索所有与指定表达式匹配的元素。这个函数是找出正在处理的元素的后代元素的好方法。

$("div").find("p")//等价于$("div p")

筛选

  筛选出与指定表达式匹配的元素集合。这个方法用于缩小匹配的范围。用逗号分隔多个表达式。

$("div").filter(".c1")//从结果集中过滤出有c1样式类的   等价于$("div.c1")

补充

.first()//获取匹配的第一个元素
.last()//获取匹配的最后一个元素
.not()//从匹配元素的集合删除与指定表达式匹配的元素
.has()//保留包含特定后代的元素,去掉那些不含有指定后代的元素
.eq()//索引值等于指定值的元素
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>左侧菜单</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <style>
        .left {
            position: fixed;
            left: 0;
            top: 0;
            width: 20%;
            height: 100%;
            background-color: rgba(47, 53, 61);
        }

        .menu {
            color: white;
        }

        .item {
            padding: 5px 10px;
            border-bottom: 1px solid #23282e;
        }

        .title {
            text-align: center;
            padding: 10px 15px;
            border-bottom: 1px solid #23282e;
        }

        .items {
            background-color: #181c20;
        }

        .hide {
            display: none;
        }

        .right {
            width: 80%;
            height: 100%;
        }
    </style>
</head>
<body>
<div class="left">
    <div class="menu">
        <div class="item">
            <div class="title">菜单一</div>
            <div class="items">
                <div class="item">111</div>
                <div class="item">222</div>
                <div class="item">333</div>
            </div>
        </div>
        <div class="item">
            <div class="title">菜单二</div>
            <div class="items hide">
                <div class="item">111</div>
                <div class="item">222</div>
                <div class="item">333</div>
            </div>
        </div>
        <div class="item">
            <div class="title">菜单三</div>
            <div class="items hide">
                <div class="item">111</div>
                <div class="item">222</div>
                <div class="item">333</div>
            </div>
        </div>
    </div>
</div>
<div class="right"></div>
<script>
    $(".title").click(function () {
        $(this).next().removeClass("hide").parent().siblings().find(".items").addClass("hide")
    })
</script>
</body>
</html>
左侧菜单

操作标签

样式操作

样式类
addClass();//添加指定的CSS类名。
removeClass();//移除指定的CSS类名。
hasClass();//判断样式存不存在
toggleClass();//切换CSS类名,如果有就移除,如果没有就添加。
CSS
css("color","red");//DOM操作:tag.style.color="red"

示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>css操作</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <p>我是p标签</p>
</body>
</html>
$("p").css("color","red");//将所有p标签的字体设置为红色
$('p').css('font-size','24px');//将所有p标签的字体设置为24px;
$('p').css('font-size');//当里面是一个参数是获取所有p标签的字体大小

位置操作

offset();//获取匹配元素在当前窗口的相对偏移或设置元素位置
position();//获取匹配元素相对父元素的偏移
scrollTop();//获取匹配元素相对滚动条顶部的偏移
scrollLeft();//获取匹配元素相对滚动条左侧的偏移

示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>位置操作</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <style>
        div{
            position: relative;
            left: 200px;
            height: 200px;
            background-color: red;
            width: 200px;
            top:200px;
        }
    </style>
</head>
<body>
    <div>div</div>
</body>
</html>
$("div").offset({left:400});//获取匹配div在当前窗口的相对偏移400px
$("div").offset();//获取匹配的div在对当前上面位置
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>定位相关</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <style>
        .c1{
            height: 100px;
            width: 100px;
            background-color: blue;
            position: relative;
        }
        .c2{
            height: 200px;
            width: 200px;
            background-color: red;
            position: absolute;
            top: 100px;
            left: 200px;
        }
    </style>
</head>
<body>
<div class="c1">
    <div class="c2">

    </div>
</div>
</body>
</html>
$(".c2").position();//只能获取值  {top: 100, left: 200}
$(".c2").position({left:400,top:200});//{top: 100, left: 200}

.offset()方法允许我们检索一个元素相对于文档(document)的当前位置。和.position的差别在于:.position()是相对于父级元素的偏移。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>鼠标滚动</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <style>
        .c1 {
            width: 100px;
            height: 200px;
            background-color: red;
        }

        .c2 {
            height: 50px;
            width: 50px;
            position: fixed;
            bottom: 15px;
            right: 15px;
            background-color: #2b669a;
        }

        .hide {
            display: none;
        }

        .c3 {
            height: 100px;
        }
    </style>
</head>
<body>
<button id="b1" class="btn btn-default">点我</button>
<div class="c1"></div>
<div class="c3">1</div>
<div class="c3">2</div>
<div class="c3">3</div>
<div class="c3">4</div>
<div class="c3">5</div>
<div class="c3">6</div>
<div class="c3">7</div>
<div class="c3">8</div>
<div class="c3">9</div>
<div class="c3">10</div>
<div class="c3">11</div>
<div class="c3">12</div>
<div class="c3">13</div>
<div class="c3">14</div>
<div class="c3">15</div>
<div class="c3">16</div>
<div class="c3">17</div>
<div class="c3">18</div>
<div class="c3">19</div>
<div class="c3">20</div>
<div class="c3">21</div>
<div class="c3">22</div>
<div class="c3">23</div>
<div class="c3">24</div>
<div class="c3">25</div>
<div class="c3">26</div>
<div class="c3">27</div>
<div class="c3">28</div>
<div class="c3">29</div>
<div class="c3">30</div>
<div class="c3">31</div>
<div class="c3">32</div>
<div class="c3">33</div>
<div class="c3">34</div>
<div class="c3">35</div>
<div class="c3">36</div>
<div class="c3">37</div>
<div class="c3">38</div>
<div class="c3">39</div>
<div class="c3">40</div>
<div class="c3">41</div>
<div class="c3">42</div>
<div class="c3">43</div>
<div class="c3">44</div>
<div class="c3">45</div>
<div class="c3">46</div>
<div class="c3">47</div>
<div class="c3">48</div>
<div class="c3">49</div>
<div class="c3">50</div>
<div class="c3">51</div>
<div class="c3">52</div>
<div class="c3">53</div>
<div class="c3">54</div>
<div class="c3">55</div>
<div class="c3">56</div>
<div class="c3">57</div>
<div class="c3">58</div>
<div class="c3">59</div>
<div class="c3">60</div>
<div class="c3">61</div>
<div class="c3">62</div>
<div class="c3">63</div>
<div class="c3">64</div>
<div class="c3">65</div>
<div class="c3">66</div>
<div class="c3">67</div>
<div class="c3">68</div>
<div class="c3">69</div>
<div class="c3">70</div>
<div class="c3">71</div>
<div class="c3">72</div>
<div class="c3">73</div>
<div class="c3">74</div>
<div class="c3">75</div>
<div class="c3">76</div>
<div class="c3">77</div>
<div class="c3">78</div>
<div class="c3">79</div>
<div class="c3">80</div>
<div class="c3">81</div>
<div class="c3">82</div>
<div class="c3">83</div>
<div class="c3">84</div>
<div class="c3">85</div>
<div class="c3">86</div>
<div class="c3">87</div>
<div class="c3">88</div>
<div class="c3">89</div>
<div class="c3">90</div>
<div class="c3">91</div>
<div class="c3">92</div>
<div class="c3">93</div>
<div class="c3">94</div>
<div class="c3">95</div>
<div class="c3">96</div>
<div class="c3">97</div>
<div class="c3">98</div>
<div class="c3">99</div>
<div class="c3">100</div>

<button id="b2" class="btn btn-default c2 hide">返回顶部</button>
<script>
    $("#b1").on("click",function () {
        $(".c1").offset({left:200,top:200});
    });
    $(window).scroll(function () {
        if ($(window).scrollTop()>100){
            $("#b2").removeClass("hide");
        }
    });
    $("#b2").on("click",function () {
        $(window).scrollTop(0)
    })
</script>
</body>
</html>
回到顶部:

尺寸

height()//文本长度
width()//文本宽度
innerHeigth()//文本加padding长度
innerwidth()//文本加padding宽度
outerHeigth()//文本加padding加border长度
outerWidth()//文本加padding加border宽度

文本操作

HTML代码:
html()//取得第一个匹配元素的html内容
html(val)//设置所有匹配元素的html内容
文本值:
val()//取得第一个匹配元素的当前值
val(val)//设置所有匹配元素的值
val([val1,val2])//设置多选的checkbox、多选select的值

例如:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<input type="checkbox" value="basketball" name="hobby">篮球
<input type="checkbox" value="football" name="hobby">足球
<select multiple id="s1">
    <option value="1">1</option>
    <option value="2">2</option>
    <option value="3">3</option>
</select>
</body>
</html>
$("[name='hobby']").val(['basketball','football']);
$('#s1').val(["1","2"]);

示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<label for="c1"></label>
<input type="radio" id="c1" name="gender" value="0">
<label for="c2"></label>
<input type="radio" id="c2" name="gender" value="1">
</body>
</html>
$("input[name='gender']:checked").val();
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<form action="">
    <p>username:
        <input type="text" id="username">
        <span class="errors"></span>
    </p>
    <p>password:
        <input type="text" id="password">
        <span class="errors"></span>
    </p>
    <input type="submit" id="b1">
</form>
<script>
    $('#b1').on('click', function () {
        let username = $('#username').val();
        let password = $('#password').val();
        if (username.length === 0) {
            $('.errors').first().text('用户名不能为空!')
        }
        if (password.length === 0) {
            $('.errors').last().text('密码不能为空!')
        }
        return false
    });
    $('#username').on('focus',function () {
        $('.errors').first().text('')
    })
    $('#password').on('focus',function () {
        $('.errors').last().text('')
    })
</script>
</body>
</html>
登录校验示例

属性操作

用于ID等或自定义属性:
attr(attrName)//返回第一个匹配元素的属性值
attr(attrName,attrValue)//为所有匹配元素设置一个属性值
attr({k1:v1,k2:v2})//为所有匹配元素设置多个属性值
removeAttr()//从每一个匹配的元素中删除一个属性
用于checkbox和radio:
prop()//获取属性
removeProp()//移除属性

示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <p id="1" xxx="xxxdsb">p</p>
    <input type="checkbox" name="hobby" id="d1" checked="checked">篮球
    <input type="checkbox" name="hobby" id="d2">足球
    <input type="checkbox" name="hobby" id="d3">双色球
</body>
</html>
$('p').attr('xxx');
$('p').attr('id');
$('p').attr('yyy','tom');
$('p').removeAttr('yyy');
$('#d1').attr('checked');
$('#d2').attr('checked');
$('#d2').prop('checked');
$('#d1').prop('checked');
$('#d1').prop('checked',false);

prop和attr的区别:

attr全称attribute(属性)

prop全称property(属性)

虽然都是属性,但是他们所指的属性并不相同,attr所指的属性是HTML标签属性,而prop所指的是DOM对象属性,可以认为attr是显式的,而prop是隐式的。

 举个例子:

<input type="checkbox" id="i1" value="1">

针对上面的代码:

$("#i1").attr("checked")  // undefined
$("#i1").prop("checked")  // false

可以看到attr获取一个标签内没有的东西会得到undefined,而prop获取的是这个DOM对象的属性,因此checked为false。

如果换成下面的代码:

<input type="checkbox" checked id="i1" value="1">

再执行:

$("#i1").attr("checked")   // checked
$("#i1").prop("checked")  // true

这已经可以证明attr的局限性,它的作用范围只限于HTML内的属性,而prop获取的是这个DOM对象的属性,选中返回true,没选中返回false。

接下来再看一下针对自定义属性,attr和prop又有上面区别:

<input type="checkbox" checked id="i1" value="1" me="自定义属性">

执行以下代码:

$("#i1").attr("me")   // "自定义属性"
$("#i1").prop("me")  // undefined

可以看到prop不支持获取标签的自定义属性。

总结:

1.对于标签上有的能看到的属性和自定义属性都用attr

2.对于返回布尔值的比如checkbox、radio和option是否被选中都用prop。

文档处理

添加到指定元素内部的后面
$(A).append(B)//把B追加到A
$(A).appendTo(B)//把A追加到B
添加到指定元素内部的前面
$(A).prepend(B)//把B前置到A
$(B).prependTo(B)//把A前置到B 
添加到指定元素外部的后面
$(A).after(B)//把B放到A的后面
$(A).insertAfter(B)//把A放到B的后面
添加到指定元素外部的前面
$(A).before(B)//把B放到A的前面
$(A).insertBefore(B)//把A放到B的前面
移除和清空元素
remove()//从DOM中删除所有匹配的元素
empty()//删除匹配的元素集合中所有的子节点
替换
replaceWith()
replaceAll()
克隆
clone()//参数
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <style>
        button{
            background-color: lightpink;
        }
    </style>
</head>
<body>
    <button>你无法逃脱死亡的阴影!</button>

</body>
<script>
    $('button').on("click",function () {
        $(this).clone(true).insertAfter(this);
    })
</script>
</html>
克隆示例:

事件

常用事件

click(function ( {...})//单击事件
hover(function ( {...})//悬浮事件
blur(function ( {...})//失焦事件
focus(function ( {...})//聚焦事件
change(function ( {...})//改变事件
keyup(function ( {...})//按键释放事件

keydown和keyup事件组合示例:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta http-equiv="content-Type" charset="UTF-8">
    <meta http-equiv="x-ua-compatible" content="IE=edge">
    <title>Title</title>
</head>
<body>


<table border="1">
  <thead>
  <tr>
    <th>#</th>
    <th>姓名</th>
    <th>操作</th>
  </tr>
  </thead>
  <tbody>
  <tr>
    <td><input type="checkbox"></td>
    <td>Egon</td>
    <td>
      <select>
        <option value="1">上线</option>
        <option value="2">下线</option>
        <option value="3">停职</option>
      </select>
    </td>
  </tr>
  <tr>
    <td><input type="checkbox"></td>
    <td>Alex</td>
    <td>
      <select>
        <option value="1">上线</option>
        <option value="2">下线</option>
        <option value="3">停职</option>
      </select>
    </td>
  </tr>
  <tr>
    <td><input type="checkbox"></td>
    <td>Yuan</td>
    <td>
      <select>
        <option value="1">上线</option>
        <option value="2">下线</option>
        <option value="3">停职</option>
      </select>
    </td>
  </tr>
  <tr>
    <td><input type="checkbox"></td>
    <td>EvaJ</td>
    <td>
      <select>
        <option value="1">上线</option>
        <option value="2">下线</option>
        <option value="3">停职</option>
      </select>
    </td>
  </tr>
  <tr>
    <td><input type="checkbox"></td>
    <td>Gold</td>
    <td>
      <select>
        <option value="1">上线</option>
        <option value="2">下线</option>
        <option value="3">停职</option>
      </select>
    </td>
  </tr>
  </tbody>
</table>

<input type="button" id="b1" value="全选">
<input type="button" id="b2" value="取消">
<input type="button" id="b3" value="反选">


<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
<script>

    var flag = false;
    // shift按键被按下的时候
    $(window).keydown(function (event) {
        console.log(event.keyCode);
        if (event.keyCode === 16){
            flag = true;
        }
    });
    // shift按键被抬起的时候
    $(window).keyup(function (event) {
        console.log(event.keyCode);
        if (event.keyCode === 16){
            flag = false;
        }
    });
    // select标签的值发生变化的时候
    $("select").change(function (event) {
        // 如果shift按键被按下,就进入批量编辑模式
        // shift按键对应的code是16
        // 判断当前select这一行是否被选中
        console.log($(this).parent().siblings().first().find(":checkbox"));
        var isChecked = $(this).parent().siblings().first().find(":checkbox").prop("checked");
        console.log(isChecked);
        if (flag && isChecked) {
            // 进入批量编辑模式
            // 1. 取到当前select选中的值
            var value = $(this).val();
            // 2. 给其他被选中行的select设置成和我一样的值
            // 2.1 找到那些被选中行的select
            var $select = $("input:checked").parent().parent().find("select")
            // 2.2 给选中的select赋值
            $select.val(value);
        }
    });
</script>
</body>
</html>
案例
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <p>来玩吗?</p>
    <script>
        $('p').hover(
            function () {
                alert('没钱,滚蛋!')
            },
            function () {
                alert('下次再来哦,老板!')
            }
        )
    </script>
</body>
</html>
hover事件示例
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <input type="text">
    <script>
        $('input').on('input',function () {
            console.log($(this).val());
        })
    </script>
</body>
</html>
实时监听input输入值变化示例

事件绑定

.on(events[,selector],function(){})

  1. event:事件
  2. selector:选择器(可选的)
  3. function:事件处理函数

移除事件

 .off(event[,selector][,function(){}])

 off()方法移除用 .on()绑定的事件处理程序。

  1. event:事件
  2. selector:选择器(可选的)
  3. function:事件处理函数

阻止后续事件执行

 return false;//常见阻止表单提交等

 e.preventDefault();

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<form action="">
    <input type="submit">
</form>
<script>
    $('input').click(function (e) {
        console.log(123);
        //第一种取消默认事件的方式
        //return false
        e.preventDefault();
    })
</script>
</body>
</html>

 注意:

 像click、keydown等DOM中定义的事件,我们都可以使用.on()方法来绑定事件,但是hover这种jQuery中定义的事件就不能用.on()方法来绑定了。

 想使用事件委托的方式绑定hover事件处理函数,可以参照如下代码分两步绑定事件:

$('ul').on('mouseenter', 'li', function() {//绑定鼠标进入事件
    $(this).addClass('hover');
});
$('ul').on('mouseleave', 'li', function() {//绑定鼠标划出事件
    $(this).removeClass('hover');
});

阻止事件冒泡

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <div>div
        <p>p
            <span>span</span>
        </p>
    </div>
<script>
    $('div').click(function () {
        alert('div')
    });
        $('p').click(function () {
        alert('p')
    });
            $('span').click(function () {
        alert('span')
    });
</script>
</body>
</html>
案例

页面载入

当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。这是事件模块中最重要的一个函数,因为它可以极大地提高web应用程序的响应速度。

三种写法:

$(document).ready(function(){
// 在这里写你的JS代码...
})

简写:

$(function(){
// 你在这里写你的代码
})

可以直接写在body的最后

与window.onload的区别

  1. window.onload()函数有覆盖现象,必须等待着图片资源加载完成之后才能调用。
  2. jQuery的这个入口函数没有函数覆盖现象,文档加载完成之后就可以调用(建议使用此函数)

事件委托

 事件委托是通过事件冒泡的原理,利用父标签去捕获子标签的事件。

 示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
    <button>点我</button>
    <script>
        // $('button').click(function () {
        //    alert(123) 
        // });
        $('body').on('click','button',function () {
            alert(123);
        })
    </script>
</body>
</html>

动画效果

// 基本
show([s,[e],[fn]])
hide([s,[e],[fn]])
toggle([s],[e],[fn])
// 滑动
slideDown([s],[e],[fn])
slideUp([s,[e],[fn]])
slideToggle([s],[e],[fn])
// 淡入淡出
fadeIn([s],[e],[fn])
fadeOut([s],[e],[fn])
fadeTo([[s],o,[e],[fn]])
fadeToggle([s,[e],[fn]])
// 自定义(了解即可)
animate(p,[s],[e],[fn])

 示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <style>
        div{
            height: 800px;
            width: 400px;
            background-color: deeppink;
        }
    </style>
</head>
<body>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
</body>
</html>
$('div').hide(3000);
$('div').show(3000);
$('div').slideUp(3000);
$('div').slideDown(3000);
$('div').fadeOut(3000);
$('div').fadeIn(3000);
$('div').fadeTo(3000,0.4);
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
    <style>
        div{
            position: relative;
            display: inline-block;
        }
        div>i{
            display: inline-block;
            color: red;
            position: absolute;
            right: -16px;
            top: -5px;
            opacity: 1;
        }
    </style>
</head>
<body>
    <div id="d1">点赞</div>
    <script>
        $("#d1").on("click",function () {
            var newI = document.createElement("i");
            newI.innerText="+1";
            $(this).append(newI);
            $(this).children("i").animate({
                opacity:0
            },1000)
        })
    </script>
</body>
</html>
点赞案例

补充

each

jQuery.each(collection, callback(indexInArray, valueOfElement)):

描述:一个通用的迭代函数,它可以用来无缝迭代对象和数组。数组和类似数组的对象通过一个长度属性(如一个函数的参数对象)来迭代数字索引,从0到length - 1。其他对象通过其属性名进行迭代。

li =[10,20,30,40]
$.each(li,function(i, v){
  console.log(i, v);//index是索引,ele是每次循环的具体元素。
})

输出:

010
120
230
340
.each(function(index, Element)):

描述:遍历一个jQuery对象,为每个匹配元素执行一个函数。

.each()方法用来迭代jQuery对象中的每一个DOM元素。每次回调函数执行时,会传递当前循环次数作为参数(从0开始计数)。由于回调函数是在当前DOM元素为上下文的语境中触发的,所以关键字 this总是指向这个元素。

// 为每一个li标签添加foo
$("li").each(function(){
  $(this).addClass("c1");
});

注意: jQuery的方法返回一个jQuery对象,遍历jQuery集合中的元素 - 被称为隐式迭代的过程。当这种情况发生时,它通常不需要显式地循环的 .each()方法:

也就是说,上面的例子没有必要使用each()方法,直接像下面这样写就可以了:

$("li").addClass("c1");  // 对所有标签做统一操作

注意:

在遍历过程中可以使用return false提前结束each循环。

终止each循环
return false

data

在匹配的元素集合中的所有元素上存储任意相关数据或返回匹配的元素集合中的第一个元素的给定名称的数据存储的值。

.data(key, value):

描述:在匹配的元素上存储任意相关数据。

$("div").data("k",100);//给所有div标签都保存一个名为k,值为100

.data(key):

描述: 返回匹配的元素集合中的第一个元素的给定名称的数据存储的值—通过 .data(name, value)或 HTML5 data-*属性设置。

$("div").data("k");//返回第一个div标签中保存的"k"的值

.removeData(key):

描述:移除存放在元素上的数据,不加key参数表示移除所有保存的数据。

$("div").removeData("k");  //移除元素上存放k对应的数据

 

原文地址:https://www.cnblogs.com/ShenJunHui6/p/10674108.html