Web前端-JavaScript(BOM)

news2024/11/16 1:53:20

文章目录

    • 1.1 常用的键盘事件
      • 1.1.1 键盘事件
      • 1.1.2 键盘事件对象
      • 1.1.3 案例一
    • 1.2 BOM
      • 1.2.1 什么是BOM
      • 1.2.2 BOM的构成
      • 1.2.3 window
      • 1.2.4 window对象常见事件
        • 窗口/页面加载事件
          • **第1种**
          • **第2种**
        • 调整窗口大小事件
      • 1.2.5 定时器
        • setTimeout() 炸弹定时器
          • 停止定时器
          • **案例:**
        • setInterval() 闹钟定时器
          • 停止定时器
          • 定时器叠加问题
          • 案例
      • 1.2.6 this指向问题
      • 1.2.7 location对象
        • 什么是 location 对象
        • URL
        • location 对象的属性
        • 案例二
    • 1.3 JS执行机制
      • 1.3.1 JS 是单线程
      • 1.3.2 同步任务和异步任务
        • 同步
        • 异步
      • 1.3.3 JS执行机制(事件循环)

1.1 常用的键盘事件

1.1.1 键盘事件

键盘事件触发条件
onkeydown按键被按下时触发
onkeypress按键被按下时触发
onkeyup按键被松开时触发

注意:addEventListener事件不需要加on

<script>
  //1. keydown 按键按下的时候触发,按任意键都触发,也可以识别功能键 如ctrl,shift,左右箭头等
  document.addEventListener('keydown', function () {
    console.log('我按下了down');
  })
  //2. keypress 按键按下的时候触发, 按任意键都触发,但不识别功能键 如ctrl,shift,左右箭头等
  document.addEventListener('keypress', function () {
    console.log('我按下了press');
  })
  //3. keyup 按键弹起的时候触发,按任意键都触发,也可以识别功能键 如ctrl,shift,左右箭头等
  document.addEventListener('keyup', function () {
    console.log('我弹起了');
  })
</script>

1.1.2 键盘事件对象

使用keyCode属性判断用户按下哪个键

键盘事件对象<属性>说明
keyCode返回该键的ASCII值

注意:

  1. onkeydown和onkeyup 不区分字符大小写,onkeypress区分字符大小写
<script>
  document.addEventListener('keyup', function (e) {
    console.log(e.keyCode);
    //keyup和keydown事件不区分字母大小写  a 和 A 得到的ASCII值是65
    if (e.keyCode == 65) {
      console.log('用户按下了a/A键');
    }
  });
  document.addEventListener('keydown', function (e) {
    //keyup和keydown事件不区分字母大小写  a 和 A 得到的ASCII值是65
    if (e.keyCode == 65) {
      console.log('用户按下了a/A键');
    }
  });
  document.addEventListener('keypress', function (e) {
    //keypress事件区分字母大小写  (a 97和A 65)
    if (e.keyCode == 65) {
      console.log('用户按下了A键');
    }
    if (e.keyCode == 97) {
      console.log('用户按下了a键');
    }
  });
</script>

1.1.3 案例一

模拟京东按键输入内容

当我们按下s键, 光标就定位到搜索框(文本框获得焦点)

<body>
  <input type="text" />

  <script>
    var text = document.querySelector('input');
    document.addEventListener('keyup', function (e) {
      if (e.keyCode === 83) {
        //获取焦点
        text.focus();
      }
    });
  </script>
</body>

1.2 BOM

1.2.1 什么是BOM

​ BOM(Browser Object Model)即浏览器对象模型,它提供了独立于内容而与浏览器窗口进行交互的对象,其核心对象是 window。

​ BOM 由一系列相关的对象构成,并且每个对象都提供了很多方法与属性。

​ BOM 缺乏标准,JavaScript 语法的标准化组织是 ECMA,DOM 的标准化组织是 W3C。

DOMBOM
文档对象模型浏览器对象模型
DOM把文档看作一个对象BOM把浏览器当作一个对象
DOM顶层对象是documentBOM顶层对象是window
DOM学习的是如何操作页面的元素BOM学习的是浏览器窗口交互的的对象
DOM是W3C标准规范BOM是浏览器厂商在各自浏览器上定义的,兼容性差

1.2.2 BOM的构成

BOM 比 DOM 更大,它包含 DOM。

image-20230301113414030

1.2.3 window

  1. window对象是浏览器的顶级对象
  2. 它是JS访问浏览器窗口的一个接口
  3. 它是一个全局对象,之前学过的alert()、prompt()、log();等都属于window
  <script>
    window.console.log("码上未来");
    window.alert('666');
    window.prompt("请输入");
    window.confirm('正确吗');
    
    var age = 23;
    console.log(window.age)
  </script>

1.2.4 window对象常见事件

窗口/页面加载事件
第1种
  1. window.onload 是窗口 (页面)的加载事件,当文档内容完全加载完成会触发该事件(包括图像、CSS、JS 文件等)就调用的处理函数。

    可以认为是同步的。

  2. 语法:

    1. window.onload = function( ){ }
    2. window.addEventListener(“load”,function( ){ });
  3. 注意:

    1. window.onload可以把JS代码写到页面元素的上方,因为onload是等页面所有内容加载完才回去执行处理函数
第2种
  1. DOMContentLoaded 事件触发时,仅当DOM元素结构加载完成执行,不包括CSS,JS,图像等等。
  2. 语法
    1. document.addEventListener(‘DOMContentLoaded’,function(){ });
  3. 注意:
    1. 如果页面的图片很多的话, 从用户访问到onload触发可能需要较长的时间, 交互效果就不能实现,必然影响用户的体验,
    2. 此时用 DOMContentLoaded 事件比较合适,可以认为DOMContentLoaded是异步的
<head>
  <meta charset="UTF-8">
  <script>
    window.onload = function () {
      var btn = document.querySelector('button');
      btn.onclick = function () {
        alert("button1");
      }
    }
    window.addEventListener('load', function () {
      var btn = document.querySelector('button');
      btn.onclick = function () {
        alert("button2");
      }
    })

    window.addEventListener('DOMContentLoaded', function () {
      var btn = document.querySelector('button');
      btn.onclick = function () {
        alert("button3");
      }
    })
  </script>
</head>

<body>
  <button>按钮</button>
</body>
</html>
调整窗口大小事件
  1. window.onresize 是调整窗口大小加载事件, 当触发时就调用的处理函数。
  2. 语法:
    1. window.onresize = function(){}
    2. window.addEventListener(‘resize’, function() { } )
  3. 注意:
    1. 只要窗口大小发生像素变化,就会触发这个事件。
    2. 我们经常利用这个事件完成响应式布局。 window.innerWidth 当前屏幕的宽度
<body>
  <div></div>
  <script>
    var div = document.querySelector('div');

    window.addEventListener('resize', function () {
      console.log(window.innerWidth);

      if (window.innerWidth > 1000) {
        div.style.width = '800px';
      } else {
        div.style.width = '600px';
      }
    })
  </script>
</body>

1.2.5 定时器

  • setTimeout()

  • setInterval()

setTimeout() 炸弹定时器
  1. 开启定时器,时间到了就执行,只执行一次。
  2. 语法:
    1. window.setTimeout( function( ){ },[延迟毫秒数])
  3. 注意:
    1. window可以省略
    2. 延迟毫秒数默认是0,如果写必须是毫秒
普通函数是按照代码顺序直接调用。
回调,就是回头调用的意思。上一件事干完,再回头再调用这个函数。
例如:定时器中的调用函数,事件处理函数,也是回调函数。
<script>
    // setTimeout 只是执行一次的定时器

    // 1. 执行函数是匿名函数,
    // window.setTimeout(function () {
    //   alert('💣爆炸了!');
    // }, 2000);

    // 2. 执行函数是命名函数
    // window.setTimeout(fn, 2000);
    // function fn() {
    //   alert('💣爆炸了!');
    // }

    //3.使用较少,平时不推荐,但是如果需要传参可以使用
    setTimeout('fn(2)', 2000);
    function fn(n) {
      alert(n + 's时间到了');
    }
  </script>
停止定时器
  1. clearTimeout()方法取消了先前通过setTimeout()建立的定时器
  2. 语法:
    1. window.clearTimeout(timeoutID)
  3. 注意:
    1. window可以省略
    2. 创建定时器时候用添加一个标识符
    3. timeoutID是定时器标识符
<body>
  <button>点击停止定时器</button>
  <script>
    var timeoutID = setTimeout(function () {
      alert('💣爆炸了!');
    }, 3000);

    var btn = document.querySelector('button');
    btn.onclick = function () {
      // 清除对应的定时器任务
      window.clearTimeout(timeoutID);
    };
  </script>
</body>
案例:

5秒后关闭广告

<body>
  <img src="images/ad.jpg" alt="" class="ad" />
  <script>
    var img = document.querySelector('.ad');
    window.setTimeout(function () {
      img.style.display = 'none';
    }, 3000);
  </script>
</body>
setInterval() 闹钟定时器
  1. 该方法重复调用一个函数,每隔指定时间就工作一次。
  2. 语法:
    1. window.setInterval(function( ) { }, [间隔毫秒数] )
  3. 注意:
    1. window可以省略
    2. 默认间隔时间是0,如果写就必须是毫秒
<script>
    // 他与闹钟定时的唯一区别就是可以执行多次!
    window.setInterval(function () {
      console.log('我很帅!');
    }, 1000);
  </script>
停止定时器
  1. clearInteval()方法取消了先前通过clearInteval()建立的定时器
  2. 语法:
    1. window.clearInterval(intervalID);
  3. 注意:
    1. window可以省略
    2. intervalID就是定时器的标识符
<body>
  <button class="begin">开启定时器</button>
  <button class="stop">停止定时器</button>
  <script>

    var timeId = null;
    var begin = document.querySelector('.begin');
    var stop = document.querySelector('.stop');

    begin.onclick = function () {
      timeId = setInterval(function () {
        console.log('开始工作');
      }, 1000);
    };

    stop.onclick = function () {
      clearInterval(timeId);
    };
  </script>
</body>
定时器叠加问题

如果一直点击定时器,会发现无法关闭定时器

<body>
  <button class="begin">开启定时器</button>
  <button class="stop">停止定时器</button>
  <script>

    var timeId = null;
    var isExit = false;
    var begin = document.querySelector('.begin');
    var stop = document.querySelector('.stop');

    //  开关灯 布尔值来控制定时器叠加问题
    begin.onclick = function () {
      if (isExit == false) {
        isExit = true;
        timeId = setInterval(function () {
          console.log('开始工作');
        }, 1000);
      }
    };

    stop.onclick = function () {
      if (isExit == true) {
        isExit = false
        clearInterval(timeId);
      }
    };

  </script>
</body>
案例

发送短信倒计时

点击按钮后,该按钮60秒之内不能再次点击,防止重复发送短信。

image-20230301113702199
<body>
  手机号码: <input type="number" />
  <button>发送</button>

  <script>
    // this指向问题?
    var btn = document.querySelector('button');
    var count = 3;
    btn.onclick = function () {
      this.disabled = true;
      // var that = this;
      var timerId = setInterval(function () {
        if (count == 0) {
          this.innerText = '发送';
          this.disabled = false;
          clearInterval(timerId);
          count = 3;
        } else {
          this.innerText = '剩余' + count + '秒';
          console.log(count);
          count--;
        }
      }, 1000);
    };
  </script>
</body>

1.2.6 this指向问题

  1. this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,
  2. 一般情况下this的最终指向的是那个调用它的对象。

现阶段,我们先了解一下几个this指向

  1. 全局作用域或者普通函数中this指向全局对象window(注意定时器里面的this指向window)

  2. 方法调用中谁调用this指向谁

  3. 构造函数中this指向构造函数的实例

<body>
  <button>点击</button>
  <script>
    // this 指向问题 一般情况下this的最终指向的是那个调用它的对象

    // 1. 全局作用域或者普通函数中this指向全局对象window( 注意定时器里面的this指向window)
    // window.console.log(this);//这里this指向window

    // function fn() {
    //   console.log(this);//这里this指向window
    // }
    // window.fn();

    // 2. 方法调用中谁调用this指向谁
    // var o = {
    //   name: 'zs',
    //   sayHi: function () {
    //     console.log(this); // this指向的是 o 这个对象
    //   }
    // };
    // o.sayHi();


    // 3. 事件注册中this指向事件源
    // var btn = document.querySelector('button');
    // btn.onclick = function () {
    //   console.log(this); // this指向的是btn这个按钮对象
    // };

    //4. 构造函数中this指向构造函数的实例
    // function Fun(name) {
    //   this.name = name
    //   console.log(this); // this 指向的是fun 实例对象
    // }
    // var fun = new Fun("zs");
    // var fun1 = new Fun("lisi");

    //   5.在定时器中this指向window
    // window.setInterval(function () {
    //   console.log(this);
    // }, 1000);

    //  6.自调用函数中this指向? window
    (
      function (n) {
        console.log(n);
        console.log(this);
      }
    )(5)
  </script>
</body>

1.2.7 location对象

什么是 location 对象

window对象给我们提供了一个location属性,用于获取或设置窗体的URL,并可以解析URL

URL
  1. 统一资源定位符,是互联网上标准资源的地址,互联网上的每个文件都有一个唯一的URL

  2. 语法:127.0.0.1

    1. Request URL: 协议://主机:端口/路径?参数1=值1 & 参数2 =值2

    2. http://localhost:19002/v2/goodstype/listByPage?page=1&rows=10

      组成说明
      protocolhttp协议http
      host主机,域名localhost
      port端口19002
      path接口路径,由多个/组成v2/goodstype/listByPage
      params参数,用&分隔page=1&rows=10
location 对象的属性
location对象属性返回值
location.href获取整个URL
location.search返回参数
location.pathname返回路径
location.host返回主机
location.port返回端口号

重点掌握href和search

location.href = "http://www.baidu.com"
案例二

5秒钟自动跳转页面

image-20230301113759753

<body>
  <button>立即跳转</button>
  <div>5秒以后返回首页</div>
  <script>
    var btn = document.querySelector('button');
    btn.onclick = function () {
      location.href = 'http://www.baidu.com';
    };
    setTimeout(function () {
      location.href = 'http://www.baidu.com';
    }, 5000);
  </script>
</body>

1.3 JS执行机制

以下代码执行的结果是什么?

<script>
    // 第一个问题
    // console.log(1);

    // setTimeout(function () {
    //   console.log(3);
    // }, 2000);

    // console.log(2);

 
    // 2. 第二个问题
    // console.log(1);

    // setTimeout(function () {
    //   console.log(3);
    // }, 0);

    // for (var i = 0; i < 20000; i++) {
    //   console.log(2);
    // }
 </script>

1.3.1 JS 是单线程

image-20230301114224179

	单线程就意味着,所有任务需要排队,前一个任务结束,才会执行后一个任务。如果前一个任务耗时很长,后一个任务就不得不一直等着。
	这样所导致的问题是: 如果 JS 执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的感觉。

1.3.2 同步任务和异步任务

同步

​ 前一个任务结束后再执行后一个任务,程序的执行顺序与任务的排列顺序是一致的、同步的。比如做饭的同步做法:我们要烧水煮饭,等水开了(10分钟之后),再去切菜,炒菜。

异步

​ 你在做一件事情时,因为这件事情会花费很长时间,在做这件事的同时,你还可以去处理其他事情。比如做饭的异步做法,我们在烧水的同时,利用这10分钟,去切菜,炒菜。

JS中所有任务可以分成两种,一种是同步任务(synchronous),另一种是异步任务(asynchronous)。

同步任务指的是:
	在主线程上排队执行的任务,只有前一个任务执行完毕,才能执行后一个任务;
异步任务指的是:
	不进入主线程、而进入”任务队列”的任务,当主线程中的任务运行完了,才会从”任务队列”取出异步任务放入主线程执行。
image-20230301114352656

1.3.3 JS执行机制(事件循环)

image-20230301114752124

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

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

相关文章

python 写自动点击爬取数据

今天来点不一样的&#xff01;哥们 提示&#xff1a; 这里只是用于自己学习的 &#xff0c;请勿用违法地方 效果图 会进行点击下一页 进行抓取 需要其他操作也可以自己写 文章目录 今天来点不一样的&#xff01;哥们前言一、上代码&#xff1f;总结 前言 爬虫是指通过编程自动…

Spring Framework和SpringBoot的区别

目录 一、前言 二、什么是Spring 三、什么是Spring Framework 四、什么是SpringBoot 五、使用Spring Framework构建工程 六、使用SpringBoot构建工程 七、总结 一、前言 作为Java程序员&#xff0c;我们都听说过Spring&#xff0c;也都使用过Spring的相关产品&#xff0…

基因组学之碱基突变的关键概念

碱基突变 突变&#xff08;muation&#xff09;会引起DNA序列的变化&#xff0c;进一步会引起蛋白序列的改变。正常的细胞活动或细胞与环境的随机相互作用&#xff0c;会使得生物产生一定数目的突变&#xff0c;称为自发突变&#xff08;spontaneous muation&#xff09;。突变…

多线程第一课---

UML中规定的箭头方向是从子类指向父类。 关于这一点&#xff0c;按照以下方法去理解有助于大家记住这条规则。 在定义子类时需要通过extends关键字指定父类。因此&#xff0c; 子类一定要知道父类的定义&#xff0c;而反过来&#xff0c;父类并不知道子类的定义。 只有在知道对…

Spring事务(2):声明式事务管理案例-转账(xml、注解)

1 编写转账案例&#xff0c;引出事务管理问题 需求&#xff1a;账号转账&#xff0c;Tom账号取出1000元&#xff0c;存放到Jack账号上 1.1 建表脚本&#xff08;MySQL&#xff09; CREATE TABLE t_account (id INT(11) NOT NULL AUTO_INCREMENT,name VARCHAR(20) NOT NULL,m…

Arduino开发实例-欧姆龙E3Z-D61光电传感器

欧姆龙E3Z-D61光电传感器 文章目录 欧姆龙E3Z-D61光电传感器1、E3Z-D61光电传感器介绍2、硬件准备及接线3、代码实现1、E3Z-D61光电传感器介绍 Omran 光电传感器可用于检测 5 至 100 毫米距离内的障碍物和物体。 传感器上有一个 LED,它始终熄灭,并在检测到障碍物时亮起。 您…

Plantuml之nwdiag网络图语法介绍(二十九)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

IDEA[Debug]简单说明

目录 &#x1f95e;1.打断点 &#x1f32d;2.第一组按钮 &#x1f9c2;3.第二组按钮 &#x1f953;4.参数查看 1.打断点 1.在需要断点处打上断点&#xff0c;然后点击debug运行 2.执行debug&#xff0c;直接执行到断点处 2.第一组按钮 共有8按钮&#xff0c;从左往右依…

【普中开发板】基于51单片机的简易密码锁设计( proteus仿真+程序+设计报告+讲解视频)

基于51单片机的简易密码锁设计 1.主要功能&#xff1a;资料下载链接&#xff1a; 实物图&#xff1a;2.仿真3. 程序代码4. 设计报告5. 设计资料内容清单 【普中】基于51单片机的简易密码锁设计 ( proteus仿真程序设计报告讲解视频&#xff09; 仿真图proteus8.16(有低版本) 程…

Defi安全-Monox攻击事件Foundry复现

其它相关内容可见个人主页 Mono攻击事件的介绍见&#xff1a;Defi安全–Monox攻击事件分析–phalconetherscan 1. 前情提要和思路介绍 Monox使用单边池模型&#xff0c;创建的是代币-vCash交易对&#xff0c;添加流动性时&#xff0c;只需添加代币&#xff0c;即可进行任意代…

秋招复习之堆

目录 前言 堆 堆的常用操作 堆的实现&#xff08;大根堆&#xff09; 1. 堆的存储与表示 2. 访问堆顶元素 3. 元素入堆 4. 堆顶元素出堆 Top-k 问题 方法一&#xff1a;遍历选择 方法二&#xff1a;排序 方法三&#xff1a;堆 总结 前言 秋招复习之堆。 堆 「堆 heap…

分布式系统——广播Broadcasts

1 广播抽象(Broadcast Abstractions)在进程中的两种方法 在分布式系统中广播抽象的概念。广播抽象允许系统中的进程使用两种基本方法进行通信&#xff1a; 1.1 Broadcast(m) 当一个进程 i 使用这个方法时&#xff0c;它会将消息 m 发送给系统中的所有其它进程。 1.2 …

数据结构实验1:栈和队列的应用

目录 一、实验目的 二、实验原理 1.1栈的基本操作 1.1.1 栈的定义 1.1.2 初始化栈 1.1.3 压栈&#xff08;Push&#xff09; 1.1.4 出栈&#xff08;Pop&#xff09; 1.1.5 判空&#xff08;isEmpty&#xff09; 1.1.6 查看栈顶元素&#xff08;Top&#xff09; 1.1…

【好书推荐】我的第一本科技漫画书:漫画区块链

王杰&#xff0c;南京理工大学物理电子学硕士&#xff0c;曾担任乐视VR技术总监&#xff0c;现为北京米唐科技有限公司CEO&#xff0c;知乎“区块链”领域知名作者&#xff0c;北京信息科技大学、北京建筑大学、北京信息职业技术学院客座教授。 郑巍&#xff0c;擅长绘制钢笔淡…

application.properties 如何改成 application.yml

Convert YAML and Properties File 右键直接转换即可 Further Reading &#xff1a; idea 常用插件

14_IO_其他流

文章目录 数据流DataOutputStream数据输出流DataInputStream数据输入流 打印流PrintStream字节打印流PrintWriter字符打印流 标准输入输出流标准输入流标准输出流 对象流(序列化与反序列化流)ObjectOutputStream序列化流ObjectInputStream反序列化流 RandomAccessFile随机访问文…

【Harmony OS - 网络请求】

在一个应用开发中&#xff0c;网络请求是必不可少的&#xff0c;我们一般用的fetch、axios来进行http请求&#xff0c;在鸿蒙中也可以通过createHppt来发生一个http请求&#xff0c;它们都是异步请求返回的Promise&#xff0c;下面我们将介绍’ohos.net.http’和axios这两种方式…

(21)Linux的文件描述符输出重定向

一、文件描述符 1、文件描述符的底层理解 在上一章中&#xff0c;我们已经把 fd 的基本原理搞清楚了&#xff0c;知道了 fd 的值为什么是 0,1,2,3,4,5... 也知道了 fd 为什么默认从 3 开始&#xff0c;而不是从 0,1,2&#xff0c;因为其在内核中属于进程和文件的对应关系。 …

Mysql SQL审核平台Yearning本地部署

文章目录 前言1. Linux 部署Yearning2. 本地访问Yearning3. Linux 安装cpolar4. 配置Yearning公网访问地址5. 公网远程访问Yearning管理界面6. 固定Yearning公网地址 前言 Yearning 简单, 高效的MYSQL 审计平台 一款MYSQL SQL语句/查询审计工具&#xff0c;为DBA与开发人员使用…

Python的基础练习题之学生管理系统

需求 使用Python基础写一个基于控制台的学生管理平台&#xff0c;里面功能分别是&#xff1a;1.录入学生信息2.查找学生信息3.删除学生信息4.修改学生信息5.排序6.统计学生总人数7.显示所有学生信息&#xff0c;要求数据存储在文件里。 代码 代码资源地址可以直接下载 效果图…