BOM简介

news2024/11/20 6:13:07

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.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>

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>

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

1.3 JS执行机制

1.3.1 JS 是单线程

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

1.3.2 同步任务和异步任务

同步

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

异步

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

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

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

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

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

相关文章

PhpPythonC++圆类的实现(OOP)

哎......被投诉了 &#x1f62d;&#x1f62d;&#x1f62d;&#x1f62d;&#x1f62d; 其实也不是小编不更&#xff0c;这不是期末了吗&#xff08;zhaojiekou~~&#xff09;&#xff0c;而且最近学的信息收集和ctf感觉好像没找到啥能更的&#xff08;不过最经还是在考虑更一…

Java中并发下的ThreadlocalRandom

1. 背景 在看同事写的代码的时候发现代码里有很多像&#xff1a; 如果我们想要生成一个随机数&#xff0c;通常会使用Random类。但是在并发情况下Random生成随机数的性能并不是很理想&#xff0c;今天给大家介绍一下JUC包中的用于生成随机数的类–ThreadLocalRandom.&#x…

领英Linkedin自动跳转中国站点的解决方案

linkedin放弃中国市场后&#xff0c;在国内打开linkedin.com&#xff0c;会自动跳转到 linkedin.cn&#xff0c;无法与国际友人在同一个平台上联系。 按照搜到的方法尝试解决&#xff0c;包括修改浏览器默认语言、清除浏览数据、使用软路由上的插件给 linkedin.com设置从国外线…

华为 1+X《网络系统建设与运维(高级)》认证模拟实验上机试题

华为 1X《网络系统建设与运维&#xff08;高级&#xff09;》认证模拟实验上机试题 一、考试背景二、考试说明2.1考试分数说明2.2考试要求2.3考试环境介绍2.4启动考试环境2.5保存答案(非常重要) 三、考试正文3.1注意事项3.2校区内&#xff08;LAN&#xff09;3.2.1任务 1&#…

深入浅出Go语言:匿名函数的原理和实践案例

深入浅出Go语言&#xff1a;匿名函数的原理和实践案例 引言匿名函数的基础实际应用案例一实际应用案例二性能考虑最佳实践与常见错误结语 引言 在Go语言的世界里&#xff0c;有一个功能强大且灵活的编程元素值得每位开发者深入了解——匿名函数。作为Go语言核心特性之一&#…

前端-基础 表格标签 - 基本使用及表头单元格 详解

基本使用 &#xff1a; 主要作用 &#xff1a; 即 主要 用于显示&#xff0c;展示数据&#xff0c;因为它可以让数据显示的非常的规整&#xff0c;可读性非常好。 特别是后台展示数据的时候&#xff0c;能够熟练运用表格就显得很重要。 一个清爽简约的表格能够把繁杂 的…

C2-4.3.1 多个决策树——随机森林

C2-4.3.1 多个决策树——随机森林 参考链接 1、为什么要使用多个决策树——随机森林&#xff1f; 决策树的缺点&#xff1a; A small change in the data can cause a large change in the structure of the decision tree causing instability 即&#xff1a;对数据集 中…

数据库:如何取消mysql的密码

因为调试MySQL数据接口&#xff0c;总是需要输入密码很烦&#xff0c;所以决定取消mysql的root密码&#xff0c; 网上推荐的有两种方法&#xff1a; 1、mysql命令 SET PASSWORD FOR rootlocalhostPASSWORD(); 2、运行 mysqladmin 命令 mysqladmin -u root -p password …

【源码阅读】交易池txs_pool

重要接口&#xff1a; ITxsPool的实现&#xff1a; type TxsPool struct {config TxsPoolConfigchainconfig *params.ChainConfigbc common.IBlockChaincurrentState *state.IntraBlockStatependingNonces *txNoncercurrentMaxGas uint64ctx context.Context //cance…

密码学(一)

文章目录 前言一、Cryptographic Primitives二、Cryptographic Keys2.1 Symmetric key cryptography2.2 asymmetric key cryptography 三、Confidentiality3.1 Symmetric key encryption algorithms3.2 asymmetric key block ciphers3.3 其他 四、Integrity4.1 secure hashing …

【语义解析:连接自然语言与机器智能的桥梁】

语义解析&#xff1a;连接自然语言与机器智能的桥梁 语义解析技术可以提高人机交互的效率和准确性&#xff0c;在自然语言处理、数据分析、智能客服、智能家居等领域都有广泛的应用前景。特别是在大数据时代&#xff0c;语义解析能够帮助企业更快速地从大量的数据中获取有用的…

Helix QAC 2023.4 新版支持C++20语言,带来更多性能提升!

Helix QAC 2023.4 新增功能 Helix QAC 2023.4全面支持MISRA C:2023规则&#xff0c;涵盖100%的指南。此版本还加强了对C20语言的支持&#xff0c;改进了数据流分析性能&#xff0c;并在整个产品中增加了多项用户体验改进。 增强的C20支持 此版本新增了对以下语言特性的支持&a…

永久关闭Windows更新的5种方法

很多家用电脑&#xff0c;如果系统自动更新的话&#xff0c;会变得越来越卡顿&#xff0c;且硬件型号兼容也并不完美。那么我们该如何彻底关闭Win11的自动更新呢&#xff1f;以下准备了5种方法&#xff0c;您可以根据自身实际情况选择合适的方法&#xff01; 一&#xff1a;使…

imgaug库指南(13):从入门到精通的【图像增强】之旅

引言 在深度学习和计算机视觉的世界里&#xff0c;数据是模型训练的基石&#xff0c;其质量与数量直接影响着模型的性能。然而&#xff0c;获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此&#xff0c;数据增强技术应运而生&#xff0c;成为了解决这一问题的…

【SPDK】【NoF】使用SPDK实现NVMe over Fabrics Target

本文使用两台PC&#xff0c;一台做NVMe over Fabrics Target&#xff08;服务端&#xff09;&#xff0c;一台做NVMe over Fabrics initiator&#xff08;客户端&#xff09;。首先使用SoftRoCE来实现底层的rdma传输&#xff0c;然后使用SPDK来实现NVMe over Fabrics Target。 …

首家通过中国信通院数据库迁移工具专项测试,亚信安慧AntDB受到认可!

亚信安慧数据库数据同步平台经过中国信通院第17批“可信数据库”数据库迁移工具专项测试&#xff0c;成功成为首家符合《数据库迁移工具能力要求》的产品。该平台广泛适用于多种数据迁移场景&#xff0c;具备高性能实时数据处理、断点续作、一键迁移、可视化运维等核心优势。此…

Linux第22步_安装CH340驱动和串口终端软件MobaXterm

开发板输出信息通常是采用串口&#xff0c;而计算机通常是USB接口&#xff0c;为了让他们之间能够交换数据&#xff0c;我们通常采用USB转串口的转换器来实现。目前市场上的串口转换器大多是采用CH340芯片来实现的&#xff0c;因此我们需要在计算中安装一个CH340驱动程序&#…

echarts——折线图实现不同区间不同颜色+下钻/回钻功能——技能提升

echarts——折线图实现不同区间不同颜色下钻/回钻功能——技能提升 需求场景解决步骤1&#xff1a;安装echarts插件解决步骤2&#xff1a;html代码解决步骤3&#xff1a;封装option配置和initChart渲染方法解决步骤4&#xff1a;回钻功能 需求场景 最近在写后台管理系统时&…

conda环境下Torch not compiled with CUDA enabled解决方法

1 问题描述 在运行wav2lip模型训练时&#xff0c;报如下错误&#xff1a; Traceback (most recent call last):File "D:\ml\Wav2Lip\preprocess.py", line 32, in <module>fa [face_detection.FaceAlignment(face_detection.LandmarksType._2D, flip_inputF…

线性代数——(期末突击)矩阵(下)-习题篇(初等变换求逆矩阵、矩阵乘法、求矩阵方程、求线性方程组、解齐次线性方程组)

目录 初等变换求逆矩阵 矩阵乘法 求矩阵方程 求线性方程组 解齐次线性方程组 带有未知数的方程组 初等变换求逆矩阵 如果,则A可逆&#xff0c;且 例题&#xff1a; &#xff0c;求A的逆矩阵。 矩阵乘法 求AB&#xff0c;BA. 矩阵之间的乘法是行乘以列&#xff0c;以这…