WEB APIs day3 (1)

news2024/11/24 14:02:11

一、表单全选反选案例

在这里插入图片描述在这里插入图片描述在这里插入图片描述

<!DOCTYPE html>

<html>

<head lang="en">
  <meta charset="UTF-8">
  <title>全选反选案例</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }

    table {
      border-collapse: collapse;
      border-spacing: 0;
      border: 1px solid #c0c0c0;
      width: 500px;
      margin: 100px auto;
      text-align: center;
    }

    th {
      background-color: #09c;
      font: bold 16px "微软雅黑";
      color: #fff;
      height: 24px;
    }

    td {
      border: 1px solid #d0d0d0;
      color: #404060;
      padding: 10px;
    }

    .allCheck {
      width: 80px;
    }
  </style>
</head>

<body>
  <table>
    <tr>
      <th class="allCheck">
        <input type="checkbox" name="" id="checkAll"> <span class="all">全选</span>
      </th>
      <th>商品</th>
      <th>商家</th>
      <th>价格</th>
    </tr>
    <tr>
      <td>
        <input type="checkbox" name="check" class="ck">
      </td>
      <td>小米手机</td>
      <td>小米</td>
      <td>¥1999</td>
    </tr>
    <tr>
      <td>
        <input type="checkbox" name="check" class="ck">
      </td>
      <td>小米净水器</td>
      <td>小米</td>
      <td>¥4999</td>
    </tr>
    <tr>
      <td>
        <input type="checkbox" name="check" class="ck">
      </td>
      <td>小米电视</td>
      <td>小米</td>
      <td>¥5999</td>
    </tr>
  </table>
  <script>
    // 1. 获取大复选框
    const checkAll = document.querySelector('#checkAll')
    // 2. 获取所有的小复选框
    const cks = document.querySelectorAll('.ck')
    // 3. 点击大复选框 (需要注册事件)
    checkAll.addEventListener('click', function () {
      // 得到当前大复选框的选中状态
      // console.log(this.checked); //得到true 或者是 false
      // 但是我们这里最好不用this,用checkAll,因为后面要用到遍历循环,到不同的函数里面去
      // console.log(checkAll.checked); //得到true 或者是 false
      // 4. 遍历所有的小复选框  让小复选框的checked = 大复选框的checked
      for (let i = 0; i < cks.length; i++) {
        // cks[i].checked = this.checked  这里可以用this this是指向事件的调用者 若果里面还嵌套了一个函数就会有问题,但是这里面只有一个function说明暂时没有问题   
        cks[i].checked = checkAll.checked
      }
    })
    // 5. 小复选框控制大复选框
    for (let i = 0; i < cks.length; i++) {
      // 5.1 给所有的小复选框添加点击事件
      cks[i].addEventListener('click', function () {
        // 判断选中的小复选框个数 是不是等于 总的小复选框个数
        // querySelectorAll得到一个伪数组 All 伪数组有长度
        console.log(document.querySelectorAll('.ck:checked').length === cks.length);  //写在括号里面
        // 比较运算符返回的值是布尔型
        // console.log(document.querySelectorAll('.ck:checked').length === cks.length); 
        // checkAll.checked = true
        checkAll.checked = document.querySelectorAll('.ck:checked').length === cks.length;
      })
    }
  </script>
</body>

</html>

css伪类选择器checked

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CSS伪类选择器checked</title>
    <style>
        /* css选择器是选择什么什么的,ck是选择所有的复选框,:checked是一个伪类选择器,只选择被勾选上的,没勾选上的不选 */
        /* 一勾选就变大 */
        .ck:checked {
            width: 20px;
            height: 20px;
        }
    </style>
</head>

<body>
    <!-- input:checkbox -->
    <input type="checkbox" name="" id="" class="ck">
    <!-- 判断被勾选复选框的个数等不等于总复选框的个数,如果等于就把全选框勾上 -->
</body>

</html>

二、DOM事件进阶

在这里插入图片描述

1.事件流

在这里插入图片描述

(1)事件流与两个阶段说明

在这里插入图片描述在这里插入图片描述

(2)事件捕获

在这里插入图片描述在这里插入图片描述
第三个参数我们通常是省略的,很少去使用,我们了解一下就行了。默认是false,false就是冒泡。
有些浏览器,如ie浏览器,是不支持捕获的,所以就没有。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件流</title>
    <style>
        .father {
            width: 500px;
            height: 500px;
            background-color: pink;
        }

        .son {
            width: 200px;
            height: 200px;
            background-color: purple;
        }
    </style>
</head>

<body>
    <div class="father">
        <div class="son"></div>
    </div>
    <script>
        // 捕获阶段是从大往小找,如果你给这几个盒子注册了同一个什么事件,那它在执行的时候从大往下依次流动
        const fa = document.querySelector('.father')
        const son = document.querySelector('.son')
        //    湖北 恩施 屏山大峡谷 目标(“玻璃海”) 捕获阶段
        // 屏山大峡谷 恩施 湖北  冒泡阶段
        // 去掉true,默认就是冒泡
        document.addEventListener('click', function () {
            alert('我是爷爷')
        }, true)
        fa.addEventListener('click', function () {
            alert('我是爸爸')
        }, true)
        // 阻止事件冒泡要用到事件对象 
        son.addEventListener('click', function (e) {
            alert('我是儿子')
        }, true)
    </script>
</body>

</html>

(3)事件冒泡

在这里插入图片描述在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件冒泡</title>
    <style>
        .father {
            width: 500px;
            height: 500px;
            background-color: pink;
        }

        .son {
            width: 200px;
            height: 200px;
            background-color: purple;
        }
    </style>
</head>

<body>
    <div class="father">
        <div class="son"></div>
    </div>
    <script>
        const fa = document.querySelector('.father')
        const son = document.querySelector('.son')
        // 山东  济南  蓝翔   目标(pink老师)  捕获阶段
        //  蓝翔  济南   山东   冒泡阶段
        document.addEventListener('click', function () {
            alert('我是爷爷')
        })
        fa.addEventListener('click', function () {
            alert('我是爸爸')
        })
        son.addEventListener('click', function (e) {
            alert('我是儿子')
            // 阻止流动传播  事件对象.stopPropagation()  因为这是事件对象里面的一个方法
            e.stopPropagation()
        })

    </script>
</body>

</html>

在这里插入图片描述
回调函数的第一个参数就是事件对象
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
解绑事件分两种
我们都知道函数是一个对象,给它赋值一个空对象,就把原先的给覆盖掉了
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件解绑</title>
</head>

<body>
    <button>点击</button>
    <script>
        const btn = document.querySelector('button')
        /*  // 传统的level0的写法
          btn.onclick = function () {
              alert('点击了')
              // L0事件移除解绑
              btn.onclick = null    //点击了之后就解绑,弹出一次之后再次点击就不弹了
          } */



        // L2事件移除解绑
        // 匿名函数无法被解绑
        /*  btn.addEventListener('click', function () {
             alert('点击了')
         })
         btn.removeEventListener('click',)   //匿名函数没有名字,所以这里没有办法写 */
        function fn() {
            alert('点击了')
        }
        // 外面写了一个函数,里面直接用就行了,不用写括号,如setinterval,回调函数,直接写函数名就行了
        btn.addEventListener('click', fn)
        btn.removeEventListener('click', fn)  //事件移除
    </script>
</body>

</html>

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>mouseover和mouseenter的区别</title>
    <style>
        .dad {
            width: 400px;
            height: 400px;
            background-color: pink;
        }

        .baby {
            width: 200px;
            height: 200px;
            background-color: purple;
        }
    </style>
</head>

<body>
    <div class="dad">
        <div class="baby"></div>
    </div>
    <script>
        const dad = document.querySelector('.dad')
        const baby = document.querySelector('.baby')
        // 只有一个盒子的时候,和我们的mouseenter是没有区别的
        // 两个盒子的时候,从dad经过显示经过,离开dad移动到baby的时候,就出现了问题,既显示鼠标经过又显示鼠标离开
        // 鼠标移动到子盒子这里会触发鼠标经过事件,但是子盒子没有鼠标经过事件,所以它不执行,但是我们知道事件默认都有冒泡,它会冒泡到father身上,father有鼠标经过事件,所以又会执行一次鼠标经过事件
        // 按道理孩子是属于爸爸的一部分,无论滑到哪个孩子那里都是没有离开父盒子的,不应该反复执行多次,这样会有问题,所以我们不用mouseover,out用mouseenter,leave,因为这个事件是没有冒泡的
        /*  dad.addEventListener('mouseover', function () {
             console.log('鼠标经过');
         })
         dad.addEventListener('mouseout', function () {
             console.log('鼠标离开');
         }) */
        dad.addEventListener('mouseenter', function () {
            console.log('鼠标经过');
        })
        dad.addEventListener('mouseleave', function () {
            console.log('鼠标离开');
        })
    </script>
</body>

</html>

2. 事件委托

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件委托</title>
</head>

<body>
    <!-- 事件都有两面性,冒泡也有它的好处 -->
    <!-- ul>li{第$个孩子}*5 -->
    <ul>
        <li>第1个孩子</li>
        <li>第2个孩子</li>
        <li>第3个孩子</li>
        <li>第4个孩子</li>
        <li>第5个孩子</li>
        <!-- 一个父盒子里面有很多个小盒子,不是每一个小盒子点击之后都需要变色的 -->
        <p>我不需要变色</p>
    </ul>
    <script>
        // li没有点击事件,但是它会冒泡到ul身上,ul有点击事件
        // 点击每个小li 当前li 文字变为红色
        // 按照事件委托的方式  委托给父级,事件写到父级身上
        // 1. 获得父元素
        const ul = document.querySelector('ul')
        ul.addEventListener('click', function (e) {
            // alert(11)
            // 事件委托有一个特点,委托给了父亲,但是我们想点哪一个li就让哪个小li变红
            // 得到点的那个元素,就要用到事件对象e
            // this.style.color = 'red'
            // console.log(e);
            // console.log(e.target);    //就是我们点击的那个对象
            // e.target.style.color = 'red'
            // 我们的需求,只有点击li才会有效果
            // console.dir(e.target);    // dir是打印对象  e.target是我们点击的那个对象
            // 我们看到LI 是字符串
            if (e.target.tagName === 'LI') {
                e.target.style.color = 'red'
            }
        })
    </script>
</body>

</html>

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>自定义属性</title>
</head>

<body>
    <div data-id="0"></div>
    <script>
        const div = document.querySelector('div')
        // dataset是data-开头的属性的集合
        console.log(div.dataset.id);
    </script>
</body>

</html>
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8" />
  <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <title>tab栏切换</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }

    .tab {
      width: 590px;
      height: 340px;
      margin: 20px;
      border: 1px solid #e4e4e4;
    }

    .tab-nav {
      width: 100%;
      height: 60px;
      line-height: 60px;
      display: flex;
      justify-content: space-between;
    }

    .tab-nav h3 {
      font-size: 24px;
      font-weight: normal;
      margin-left: 20px;
    }

    .tab-nav ul {
      list-style: none;
      display: flex;
      justify-content: flex-end;
    }

    .tab-nav ul li {
      margin: 0 20px;
      font-size: 14px;
    }

    .tab-nav ul li a {
      text-decoration: none;
      border-bottom: 2px solid transparent;
      color: #333;
    }

    .tab-nav ul li a.active {
      border-color: #e1251b;
      color: #e1251b;
    }

    .tab-content {
      padding: 0 16px;
    }

    .tab-content .item {
      display: none;
    }

    .tab-content .item.active {
      display: block;
    }
  </style>
</head>

<body>
  <div class="tab">
    <div class="tab-nav">
      <h3>每日特价</h3>
      <ul>
        <li><a class="active" href="javascript:;" data-id="0">精选</a></li>
        <li><a href="javascript:;" data-id="1">美食</a></li>
        <li><a href="javascript:;" data-id="2">百货</a></li>
        <li><a href="javascript:;" data-id="3">个护</a></li>
        <li><a href="javascript:;" data-id="4">预告</a></li>
      </ul>
    </div>
    <div class="tab-content">
      <div class="item active"><img src="./images/tab00.png" alt="" /></div>
      <div class="item"><img src="./images/tab01.png" alt="" /></div>
      <div class="item"><img src="./images/tab02.png" alt="" /></div>
      <div class="item"><img src="./images/tab03.png" alt="" /></div>
      <div class="item"><img src="./images/tab04.png" alt="" /></div>
    </div>
  </div>
  <script>
    // 采取事件委托的形式  tab栏切换
    // 1. 获取ul 父元素  选择ul最合适 因为ul只有一个 而li也是有4个的
    const ul = document.querySelector('.tab-nav ul')
    // ----------------------------
    // 法2:获取5个 item
    const items = document.querySelectorAll('.tab-content .item')
    // -----------------------------
    // 2. 添加事件
    ul.addEventListener('click', function (e) {
      // console.log(e.target);   //e.target是我们点击的对象
      // 我们只有点击了 a 才会进行 添加类和删除类的操作
      // console.log(e.target.tagName);  //e.target.tagName  点击那个对象的标签名
      if (e.target.tagName === 'A') {
        // console.log('我选的是a');
        // 排他思想,先移除原来的active
        document.querySelector('.tab-nav .active').classList.remove('active')
        // 当前元素添加active  (点击了谁谁就是当前元素)
        // 这里不能用this 因为this是指向函数的调用者 这里函数的调用者是ul
        // e.target.tagName是用来判断选择的对象是不是A,e.target才是我们点击的对象
        // if判断语句执行了才会执行下面的
        e.target.classList.add('active')

        // 下面大盒子模块
        // 为什么写得这么麻烦,因为我们没有写for循环,拿不到i 不知道点的是第几个i。所以采用自定义属性的方式
        // console.log(e.target.dataset.id);
        // 觉得太长了,可以进行赋值操作 叫id 还是什么随意 这样索引号就有了 
        // !data-id 获取的数字有 "",说明是字符串,所以我们要把它转换成数字型 
        const i = +e.target.dataset.id
        // 排他思想 , 先移除原来的active
        document.querySelector('.tab-content .active').classList.remove('active')
        // 对应的大盒子 添加  active
        // nth-child的序号是从1开始
        // -----------------------------
        // 法1
        // document.querySelector(`.tab-content .item:nth-child(${i + 1})`).classList.add('active')
        // -----------------------------

        // 法2
        // ----------------------
        items[i].classList.add('active')
        // ---------------------------
      }
    })
  </script>
</body>

</html>

阻止默认行为发生
在这里插入图片描述在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>阻止默认行为</title>
</head>

<body>
    <form action="http://www.itcast.cn">
        <!-- input:submit -->
        <input type="submit" value="免费注册">
    </form>
    <a href="http://www.baidu.com">百度一下</a>
    <script>
        const form = document.querySelector('form')
        // 提交事件
        form.addEventListener('submit', function (e) {
            // 阻止默认行为  提交
            e.preventDefault()
        })

        const a = document.querySelector('a')
        a.addEventListener('click', function (e) {
            e.preventDefault()
        })
    </script>
</body>

</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/748012.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【ROS2】仿真入门

一、说明 在机器人项目中,仿真是一个具有多种用途的重要方面。首先,您可以测试希望机器人执行的行为代码。其次,您可以使用仿真来测试不同类型的硬件,例如距离传感器、相机或 3D 点云传感器,看看哪种效果最好。第三,可视化模拟的相同软件可以与真正的机器人实时使用,在机…

基于51单片机和proteus的智能垃圾桶系统

此系统是基于51单片机和proteus的仿真设计&#xff0c;功能如下&#xff1a; 1. LCD1602实时显示系统状态。 2. 超声波测距模拟检测人体靠近垃圾桶 3. 舵机模拟开启或关闭垃圾桶桶盖。 4. 垃圾桶满溢后报警指示。 5. LED指示人体状态满溢状态及系统状态。 功能框图如下&am…

BTP Integration Suite学习笔记 - (Unit2) Developing with SAP Integration Suite

BTP Integration Suite学习笔记 - (Unit1) Developing with SAP Integration Suite 这章内容比较大而空 Unit2 iPaaS介绍 2.1 SAP的集成策略 这张图应该不陌生&#xff0c;很多地方都可以看到&#xff0c;SAP对于智能企业的集成策略。它有四个原则&#xff1a; Predefined in…

剑指 offer 动态规划算法题:斐波那契数列(青蛙普通跳台阶)

题目描述&#xff1a;写一个函数&#xff0c;输入 n &#xff0c;求斐波那契&#xff08;Fibonacci&#xff09;数列的第 n 项&#xff08;即 F(N)&#xff09;。斐波那契数列的定义如下&#xff1a;F(0) 0, F(1) 1&#xff0c;F(N) F(N - 1) F(N - 2), 其中 N > 1.斐…

wordpress 导航栏 调用

环境&#xff1a;wordpress6、twentytwentyone模板 一、wp-content/themes/twentytwentyone/functions.php 添加以下代码&#xff1a; 1、注册 (左边是别名&#xff0c;右边是名称。别名会用在导航栏的调用上&#xff0c;名称则显示在菜单后台页面上&#xff1a;外观->菜单…

解密Sketch文件打开秘籍:简单两步操作!

虽然Figma&#xff0c;sketch,xd都很好用&#xff0c;但是设计师在设计工作流中经常会遇到无法在这三者软件中自由导入导出的情况。但是只要我们转变一下思路&#xff0c;因为这三种软件都支持导入sketch格式,所以我们只要将文件格式转成sketch&#xff0c;就能自由的在不同软件…

Visual Studio 新功能:Include 语句清理

Visual Studio 17.7 预览版 3 引入了一项新功能&#xff0c;用来提升开发者的生产力。我们很高兴地宣布这项新功能&#xff1a;Include 语句清理&#xff0c;这是一个帮助你维护干净代码的工具。如需使用此功能&#xff0c;请确保更新到最新版本的 Visual Studio 预览版。 Inc…

macOS 14 Sonama - 小记

文章目录 Sonoma 官方资讯关于 Sonama 命名关于 壁纸Sonoma 官方资讯 macOS Sonoma Preview https://www.apple.com/hk/en/macos/sonoma-preview/官方视频介绍 Apple Events --> Watch the Keynote --> 00:43:13 (约14min) https://www.apple.com/hk/en/apple-events/mac…

WEB APIs day3 (2)

3.其它事件 页面加载事件 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthde…

Mac环境下安装nginx并本地部署项目

1、前提 必须安装了homebrew&#xff0c;可在终端输入命令brew -v查看是否已经安装&#xff0c;如果输入指令出现版本号说明已经安装成功 如果未安装先安装&#xff08;homebrew官网地址&#xff09; /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/H…

vue2+echarts5:2D地图打点、下钻

准备 要实现地图可点击、下钻&#xff0c;为了使地图有3D效果&#xff0c;原本用map3D需要下载依赖echarts-gl,由于存在地图下钻后在区域内无法展示完整地图&#xff0c;改用2D地图 "echarts": "^5.4.2", // "echarts-gl": "^2.0.9"…

ChatGpt基于第三方API2D服务封装的SpringBoot starter

前置条件&#xff1a; 看下API2D官网&#xff0c;第三方API2D服务对接流程&#xff1a; 其对接文档地址 https://api2d.com/wiki/doc 一:创建一个空的Maven项目 完成后整的项目层级图如下 1.pom.xml 中添加相关依赖包 <?xml version"1.0" encoding"UTF-…

《C语言初阶篇》听说你还不会for循环的变种写法?一文教你彻底搞懂循环语句!

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏:《快速入门C语言》《C语言初阶篇》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 前言&#x1f4ac; for 语句的介绍&#x1f4ad; for循环默认可以控制几条语句&#xff1f;&#x1f4ad; for语…

vite基于vue3项目,打包之后的文件夹增加一个额外的文件夹

vite将项目打包之后&#xff0c;自动会生成一个dist文件&#xff0c;里边只有/assets,index.html,favicon.ico.这三个文件。 现在需求是打包之后&#xff0c;dist文件夹下多怎加一个healthcheck的文件夹。 功能实现&#xff1a; 使用复制的方法&#xff0c;将healthcheck文件…

[C++] 为什么头文件最好只做声明

文章目录 问题阐述问题分析和解决方法参考 问题阐述 问题描述&#xff1a; 当编译大的复杂的工程时&#xff0c;经常会遇到一个函数在头文件定义的时候&#xff0c;会导致冲突的问题&#xff1b;下图给出显性原因分析&#xff1b; 问题分析和解决方法 参考 C/C中在头文件中定义…

我爱学QT-把QT程序打包成windows文件

学习链接&#xff1a; 把QT程序打包成Windows软件_哔哩哔哩_bilibili 什么是打包和部署&#xff1f; 因为我们要把写好的程序发给用户来用&#xff0c;我们写好的源码也不能随便给别人。 怎么打包和部署&#xff1f; 1.把工程切换到release模式 这样点 &#xff0c;然后编译…

阿里大模型——通义千问

目录 前段时间世界人工智能大会在上海举行&#xff0c;我去参观感受了一下&#xff0c;整个感受是有点名不副实的&#xff0c;参展的有各种银行、车企、还有中国电信、联通三个运营商都来凑热闹了。 但是也有Google、华为、阿里、腾讯、商汤这样的大厂。现场也可以体验一些大厂…

ESP32开发板引脚介绍【附有引脚使用实例】

ESP32开发板引脚介绍 文章目录 ESP32开发板引脚介绍&#x1f468;‍&#x1f3eb;内容1&#xff1a;背景&#x1f468;‍⚖️内容2&#xff1a;限制类引脚&#x1f468;‍&#x1f4bb;内容3&#xff1a;ESP32 周边设备&#x1f349;文末备注 &#x1f468;‍&#x1f3eb; &am…

shell编程基础(第11篇:重定向)

前言 编写shell脚本程序时&#xff0c;总会使用重定向技术&#xff0c;用来永久保存程序的输出到文件中&#xff0c;或者用来从文件中提取文本到程序中&#xff0c;都支持哪些重定向呢&#xff1f; 温习3个文件描述符 1、标准输入&#xff0c;标准规定通常是键盘&#xff0c;数…

【Ajax】笔记-POST请求(原生)

POST请求 html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>AJAX POST 请求</title><…