...

蓝白

365200ok寓意365天都200ok!

Posts Categories Tags
5 4 7
Recent Articles
2025.1.1

14  days  ago

ajax学习笔记

2  days  ago

新年快乐

1  days  ago

jQuery学习笔记

2025-01-14   蓝白

📝 主旨内容

#jquery 遍历对象each方法

#写法一:

遍历对象each方法(长用在dom)

#写法二

$.each方法 (常用在数据 )

这个既能遍历 数组 也能遍历 对象

#jquery元素操作:创建元素

#1.创建元素

#2.内部添加 :

let ele = $(“

  • 我是新创建的

“);

$(‘ul’).append(ele); //这个是往后边放进去 类似原生的 appendChlid

$(‘ul’).prepend(ele); //这个是放 前面

#3.外部添加

4.删除元素

#jquery 删除商品小案例

删除当前商品要使用 $(this),在删除多个时,用到了隐式迭代。(使用了 this就避免使用隐式迭代,相当于一开始就限制了范围)

#jquery 尺寸位置操作

#尺寸操作

  1. 可以用来做 右侧的 返回顶部 按钮
  2. 可以设置点击某一个按钮后自动跳转某个位置 并且 带有动画效果

#位置操作

#jquery 事件注册方式

#1.单个事件注册

#2.事件处理on绑定一个或多个事件

例子: (以对象的方式来写)

写法一

写法二 (当多个事件的处理方式一样时)

#3.事件委派(对于 动态(后期通过js生成的)元素也可以绑定事件)

#jquery 事件解绑 以及自动触发

  • .off() //接触所有绑定的事件
  • .off(‘click) //接触所有绑定的点击事件
  • 自动触发事件

#jquery对象拷贝extend

#1.简介

#2.深拷贝和浅拷贝的区别

#jquery 多库共存 自定义变量定义符号

#1.方法一

用jquery代替$来定义

#2.方法二

let jq=$.noConflict(); //然后在这之后后的所有定义符号会失效 那么 jq就是新的定义符号

#jquery 插件 下载使用

https://www.jq22.com/

www.htmleaf.comopen in new window

https://www.dowebok.com/

图片懒加载、瀑布流插件、全屏滚动插件 等等

#TOdolist 网站案例

  • jq版:**todollist案例open in new window**

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    <!DOCTYPE html>
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
    <title>ToDoList—最简单的待办事项列表</title>
    <link rel="stylesheet" href="index.css">
    <!-- <script src="js/jquery.min.js"></script> -->
    <script src="<https://cdn.bootcdn.net/ajax/libs/jquery/3.6.3/jquery.min.js>"></script>
    <!-- <script src="js/todolist.js"></script> -->
    </head>
    <body>
    <header>
    <section>
    <label for="title">ToDoList</label>
    <input type="text" id="title" name="title" placeholder="添加ToDo" required="required" autocomplete="off" />
    </section>
    </header>
    <section>
    <h2>正在进行 <span id="todocount"></span></h2>
    <ol id="todolist" class="demo-box">
    <li>111111111111</li>
    </ol>
    <h2>已经完成 <span id="donecount"></span></h2>
    <ul id="donelist">
    <li>5555</li>
    </ul>
    </section>
    <footer>
    Copyright © 2014 todolist.cn
    </footer>
    </body>
    <script>
    xian();
    $('#title').on('keydown', function (e) {
    // console.log(e)
    if (e.keyCode == 13) {
    let duu = du(); //接收返回值 变为一个数组
    // 定义一个数组,来存储用户输入的
    if ($('#title').val() !== "") {
    let obj = [{
    title: $('#title').val(), //这个是获取输入框内容
    done: false,
    }];
    let ddd = duu.concat(obj[0]); //合并数组,完成数组的更新
    // 存到本地存储,完成更新
    cun(ddd); //这个利用形参来传值
    xian(); //渲染
    // 输入框内容清空
    $('#title').val("");
    } else {
    alert('请输入内容')
    }

    }
    })
    $('button').on('click', function () {})
    // 删除按钮
    $("#todolist").on("click", "a", function () {
    // 1.先读取所有的数据
    // 2.删除数据,并组成一个新的数组 array.splice(index,1);
    // 3.存储数据
    // 4.渲染数据
    let date = du();
    // let i = $("#todolist li a").attr("id");
    let i = $(this).attr("id");
    // console.log(i);
    date.splice(i, 1);
    // console.log(date);
    cun(date); //存储数据
    xian(); //渲染数据
    })
    // 复选框的效果
    $("#todolist,#donelist").on("click", "input", function () {
    let date = du();
    let i = $(this).nextAll("a").attr("id");
    date[i].done = $(this).prop("checked"); //同步复选框的状态
    cun(date); //存储数据
    xian(); //渲染数据
    // alert(5);
    })

    // 读取数据
    function du() {
    // 先获取thing这个数据名
    let date = JSON.parse(localStorage.getItem('thing'));
    // 判断是否是空
    if (date !== null) {
    return date;
    } else {
    return [];
    }
    }

    // 存储数据
    function cun(date) {
    localStorage.setItem('thing', JSON.stringify(date));
    // // 开始数据存储 localStorage.setItem('存储时候的名字',存储对象); 键值对的方式,只能存储字符串的形式
    // localStorage.setItem('thing', JSON.stringify(obj));
    // //将存储的字符串转回对象的形式
    // let objNew = JSON.parse(localStorage.getItem('thing'));
    // let arrr = []; //最后的存储所有数据的数组
    // arrr.push(objNew[0])
    // console.log(arrr[0]);
    }

    // 渲染数据
    function xian() {
    let objNew = du();
    // console.log(objNew);

    // 先进行一个排他,因为每次都会重新渲染
    $('#todolist,#donelist').children().remove();
    let donecount = 0; //完成总数
    let todocount = 0; //待办总数
    $.each(objNew, function (i, ele) {
    // console.log(i);//输出序号
    // console.log(ele);
    // 对渲染加一个判断, 渲染的时候对这个内容进行判断, 如果done值为true则渲染到donelist列表内
    if (ele.done) {
    $('#donelist').prepend("<li>" + "<input type='checkbox' checked='true'>" + "<p>" + ele.title +
    "</p>" +
    "<a href='javascript:;' id='" + i + "'></a>" + "</li>")
    donecount++;

    } else {
    $('#todolist').prepend("<li>" + "<input type='checkbox'>" + "<p>" + ele.title + "</p>" +
    "<a href='javascript:;' id='" + i + "'></a>" + "</li>")
    todocount++;
    }
    })
    $('#donecount').text(donecount);
    $('#todocount').text(todocount);
    }
    </script>
    </html>
    ```html
    <!DOCTYPE html>
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
    <title>ToDoList—最简单的待办事项列表</title>
    <link rel="stylesheet" href="index.css">
    <!-- <script src="js/jquery.min.js"></script> -->
    <script src="<https://cdn.bootcdn.net/ajax/libs/jquery/3.6.3/jquery.min.js>"></script>
    <!-- <script src="js/todolist.js"></script> -->
    </head>
    <body>
    <header>
    <section>
    <label for="title">ToDoList</label>
    <input type="text" id="title" name="title" placeholder="添加ToDo" required="required" autocomplete="off" />
    </section>
    </header>
    <section>
    <h2>正在进行 <span id="todocount"></span></h2>
    <ol id="todolist" class="demo-box">
    <li>111111111111</li>
    </ol>
    <h2>已经完成 <span id="donecount"></span></h2>
    <ul id="donelist">
    <li>5555</li>
    </ul>
    </section>
    <footer>
    Copyright © 2014 todolist.cn
    </footer>
    </body>
    <script>
    xian();
    $('#title').on('keydown', function (e) {
    // console.log(e)
    if (e.keyCode == 13) {
    let duu = du(); //接收返回值 变为一个数组
    // 定义一个数组,来存储用户输入的
    if ($('#title').val() !== "") {
    let obj = [{
    title: $('#title').val(), //这个是获取输入框内容
    done: false,
    }];
    let ddd = duu.concat(obj[0]); //合并数组,完成数组的更新
    // 存到本地存储,完成更新
    cun(ddd); //这个利用形参来传值
    xian(); //渲染
    // 输入框内容清空
    $('#title').val("");
    } else {
    alert('请输入内容')
    }

    }
    })
    $('button').on('click', function () {})
    // 删除按钮
    $("#todolist").on("click", "a", function () {
    // 1.先读取所有的数据
    // 2.删除数据,并组成一个新的数组 array.splice(index,1);
    // 3.存储数据
    // 4.渲染数据
    let date = du();
    // let i = $("#todolist li a").attr("id");
    let i = $(this).attr("id");
    // console.log(i);
    date.splice(i, 1);
    // console.log(date);
    cun(date); //存储数据
    xian(); //渲染数据
    })
    // 复选框的效果
    $("#todolist,#donelist").on("click", "input", function () {
    let date = du();
    let i = $(this).nextAll("a").attr("id");
    date[i].done = $(this).prop("checked"); //同步复选框的状态
    cun(date); //存储数据
    xian(); //渲染数据
    // alert(5);
    })

    // 读取数据
    function du() {
    // 先获取thing这个数据名
    let date = JSON.parse(localStorage.getItem('thing'));
    // 判断是否是空
    if (date !== null) {
    return date;
    } else {
    return [];
    }
    }

    // 存储数据
    function cun(date) {
    localStorage.setItem('thing', JSON.stringify(date));
    // // 开始数据存储 localStorage.setItem('存储时候的名字',存储对象); 键值对的方式,只能存储字符串的形式
    // localStorage.setItem('thing', JSON.stringify(obj));
    // //将存储的字符串转回对象的形式
    // let objNew = JSON.parse(localStorage.getItem('thing'));
    // let arrr = []; //最后的存储所有数据的数组
    // arrr.push(objNew[0])
    // console.log(arrr[0]);
    }

    // 渲染数据
    function xian() {
    let objNew = du();
    // console.log(objNew);

    // 先进行一个排他,因为每次都会重新渲染
    $('#todolist,#donelist').children().remove();
    let donecount = 0; //完成总数
    let todocount = 0; //待办总数
    $.each(objNew, function (i, ele) {
    // console.log(i);//输出序号
    // console.log(ele);
    // 对渲染加一个判断, 渲染的时候对这个内容进行判断, 如果done值为true则渲染到donelist列表内
    if (ele.done) {
    $('#donelist').prepend("<li>" + "<input type='checkbox' checked='true'>" + "<p>" + ele.title +
    "</p>" +
    "<a href='javascript:;' id='" + i + "'></a>" + "</li>")
    donecount++;

    } else {
    $('#todolist').prepend("<li>" + "<input type='checkbox'>" + "<p>" + ele.title + "</p>" +
    "<a href='javascript:;' id='" + i + "'></a>" + "</li>")
    todocount++;
    }
    })
    $('#donecount').text(donecount);
    $('#todocount').text(todocount);
    }
    </script>
    </html>

    核心是数据的本地存储以及对json的初步认识

    jq学习结束,完美撒花 🌸🌸🌸

    📎 链接

    视频学习:

    1. blibli:**黑马程序员前端基础教程|jQuery网页开发案例精讲_哔哩哔哩_bilibiliopen in new window**

    jq中文手册:

    1. jQuery API 中文文档 open in new window
    2. jquery在线手册|jQuery API中文手册open in new window