学习笔记整理-BOM-01-基础知识

news2024/10/6 14:36:34

一、 BOM常用对象

  • BOM(Browser Object Model,浏览器对象模型)是JS与浏览器窗口交互的接口。
  • 一些与浏览器改变尺寸、滚动条滚动相关的特效,都要借助BOM技术。

1. Window对象

  • window对象当前JS脚本运行所处的窗口,而这个窗口中包含DOM结构,window.document属性就是document对象

  • 在有标签页功能的浏览器中,每个标签都拥有自己的window对象;也就是说,同一个窗口的标签页之间不会共享一个window对象

  • 全局变量是window的属性

    • 全局变量会成为window对象的属性
          var a = 10;
          console.log(window.a == a); // true
      
    • 这就意味着,多个js文件之间是共享全局作用域的,即js文件没有作用域隔离功能。
  • 内置函数普遍是window的方法

    • 如setInterval()、alert()等内置函数,普遍是window的方法
          console.log(window.alert == alert); // true 
          console.log(window.setInterval == setInterval); // true
      
  • 窗口尺寸相关属性

    属性意义
    innerHeight浏览器窗口的内容区域的高度,包含水平滚动 条(如果有的话)
    innerWidth浏览器窗口的内容区域的宽度,包含垂直滚动 条(如果有的话)
    outerHeight浏览器窗口的外部高度
    outerWidth浏览器窗口的外部宽度
    • 获得不包含滚动条的窗口宽度,要用document.documentElement.clientWidth
      window
  • resize事件

    • 在窗口大小改变之后,就会触发resize事件,可以使用window.onresize或者window.addEventListener('resize')来绑定事件处理函数
  • 已卷动高度

    • window.scrollY属性表示在垂直方向已滚动的像素值
    • document.documentElement.scrollTop属性也表示窗口卷动高度
        var scrollTop = window.scrollY || document.documentElement.scrollTop;
      
    • document.documentElement.scrollTop不是只读的,而window.scrollY是只读的
  • scroll事件

    • 在窗口被卷动之后,就会触发scroll事件,可以使用window.onscroll或者window.addEventListener('scroll')来绑定事件处理函数

2. Navigator对象

  • window.navigator属性可以检索navigator对象,它内部含有用户此次活动的浏览器的相关属性和标识

    属性意义
    appName浏览器官方名称
    appVersion浏览器版本
    userAgent浏览器的用户代理(含有内核信息和封装壳信息)
    platform用户操作系统
  • 识别用户浏览器品牌

    • 识别用户浏览器品牌通常使用navigator.userAgent属性
         var sUsrAg = navigator.userAgent;
         if (sUsrAg.indexOf("Firefox") > -1) {
            } else if (sUsrAg.indexOf("Opera") > -1) {
            } else if (sUsrAg.indexOf("Edge") > -1) {
            } else if (sUsrAg.indexOf("Chrome") > -1) {
            } else if (sUsrAg.indexOf("Safari") > -1) { } 
              else {
            } 
      

3. History对象

  • window.history对象提供了操作浏览器会话历史的接口。
  • 常用操作就是模拟浏览器回退按钮
      history.back(); // 等同于点击浏览器的回退按钮 
      history.go(-1); // 等同于history.back();
    

4. Location对象

  • window.location标识当前所在网址,可以通过给这个属性 赋值命令浏览器进行页面跳转

         window.location = 'http://www.baidu.com';
         window.location.href = 'http://www.baidu.com';
    
  • 重新加载当前页面

    • 可以调用locationreload方法以重新加载当前页面,参数true表示强制从服务器强制加载。
        window.location.reload(true);
      
  • GET请求查询参数

    • window.location.search属性即为当前浏览器的GET请求查询参数
        // 比如网址https://www.baidu.com/?a=1&b=2
         console.log(window.location.search);  // "?a=1&b=2"
      

二、 BOM特效开发

1. 特效开发

  • 返回顶部按钮制作

    • 返回顶部的原理: 改变document.documentElement.scrollTop属性,通过定时器逐步改变此值,则将用动画形式返回顶部
      <!DOCTYPE html>
      <html lang="en">
      
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <title>Document</title>
          <style>
              body {
                  height: 5000px;
                  background-image: linear-gradient(to bottom, blue, green, yellow);
              }
      
              .backtotop {
                  width: 60px;
                  height: 60px;
                  background-color: rgba(255, 255, 255, .6);
                  position: fixed;
                  bottom: 100px;
                  right: 100px;
                  /* 小手状 */
                  cursor: pointer;
              }
          </style>
      </head>
      
      <body>
          <div class="backtotop" id="backtotopBtn">返回顶部</div>
      
          <script>
              var backtotopBtn = document.getElementById('backtotopBtn');
      
              var timer;
              backtotopBtn.onclick = function () {
                  // 设表先关
                  clearInterval(timer);
      
                  // 设置定时器
                  timer = setInterval(function () {
                      // 不断让scrollTop减少
                      document.documentElement.scrollTop -= 200;
                      // 定时器肯定要停
                      if (document.documentElement.scrollTop <= 0) {
                          clearInterval(timer);
                      }
                  }, 20);
              };
          </script>
      </body>
      
      </html>
      
  • 楼层导航小效果

    • DOM元素都有offsetTop属性,表示此元素到定位祖先元素的垂直距离
    • 定位祖先元素:在祖先中,离自己最近的且拥有定位属性的 元素
      <!DOCTYPE html>
      <html lang="en">
      
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <title>Document</title>
          <style>
              * {
                  margin: 0;
                  padding: 0;
              }
      
              .content-part {
                  width: 1000px;
                  margin: 0px auto;
                  margin-bottom: 30px;
                  background-color: #ccc;
                  font-size: 50px;
              }
      
              .floornav {
                  position: fixed;
                  right: 40px;
                  top: 50%;
                  margin-top: -100px;
                  width: 120px;
                  height: 200px;
                  background-color: orange;
              }
      
              .floornav ul {
                  list-style: none;
              }
      
              .floornav ul li {
                  width: 120px;
                  height: 40px;
                  line-height: 40px;
                  text-align: center;
                  font-size: 26px;
                  /* 小手指针 */
                  cursor: pointer;
              }
      
              .floornav ul li.current {
                  background: purple;
                  color: white;
              }
          </style>
      </head>
      
      <body>
          <nav class="floornav">
              <ul id="list">
                  <li data-n="科技" class="current">科技</li>
                  <li data-n="体育">体育</li>
                  <li data-n="新闻">新闻</li>
                  <li data-n="娱乐">娱乐</li>
                  <li data-n="视频">视频</li>
              </ul>
          </nav>
      
          <section class="content-part" style="height:674px;" data-n="科技">
              科技栏目
          </section>
      
          <section class="content-part" style="height:567px;" data-n="体育">
              体育栏目
          </section>
      
          <section class="content-part" style="height:739px;" data-n="新闻">
              新闻栏目
          </section>
      
          <section class="content-part" style="height:574px;" data-n="娱乐">
              娱乐栏目
          </section>
      
          <section class="content-part" style="height:1294px;" data-n="视频">
              视频栏目
          </section>
      
          <script>
              // 使用事件委托给li添加监听
              var list = document.getElementById('list');
              var contentParts = document.querySelectorAll('.content-part');
              var lis = document.querySelectorAll('#list li');
      
              list.onclick = function (e) {
                  if (e.target.tagName.toLowerCase() == 'li') {
                      // getAttribute表示得到标签身上的某个属性值
                      var n = e.target.getAttribute('data-n');
      
                      // 可以用属性选择器(就是方括号选择器)来寻找带有相同data-n的content-part
                      var contentPart = document.querySelector('.content-part[data-n=' + n + ']');
      
                      // 让页面的卷动自动成为这个盒子的offsetTop值
                      document.documentElement.scrollTop = contentPart.offsetTop;
                  }
              }
      
      
              // 在页面加载好之后,将所有的content-part盒子的offsetTop值推入数组
              var offsetTopArr = [];
              
              // 遍历所有的contentPart,将它们的净位置推入数组
              for (var i = 0; i < contentParts.length; i++) {
                  offsetTopArr.push(contentParts[i].offsetTop);
              }
              // 为了最后一项可以方便比较,我们可以推入一个无穷大
              offsetTopArr.push(Infinity);
      
              console.log(offsetTopArr);
      
              // 当前所在楼层
              var nowfloor = -1;
      
              // 窗口的卷动
              window.onscroll = function () {
                  // 得到当前的窗口卷动值
                  var scrollTop = document.documentElement.scrollTop;
      
                  // 遍历offsetTopArr数组,看看当前的scrollTop值在哪两个楼层之间
                  for (var i = 0; i < offsetTopArr.length; i++) {
                      if (scrollTop >= offsetTopArr[i] && scrollTop < offsetTopArr[i + 1]) {
                          break;
                      }
                  }
                  // 退出循环的时候,i是几,就表示当前楼层是几
                  // 如果当前所在楼层,不是i,表示环楼了
                  if (nowfloor != i) {
                      console.log(i);
                      // 让全局变量改变为这个楼层号
                      nowfloor = i;
      
                      // 设置下标为i的项有cur
                      for (var j = 0; j < lis.length; j++) {
                          if (j == i) {
                              lis[j].className = 'current';
                          } else {
                              lis[j].className = '';
                          }
                      }
                  }
              };
          </script>
      </body>
      
      </html>
      
  • 课程重点

    • 窗口相关属性有哪些?
    • 窗口卷动事件是什么?如何得到卷动值?
    • Navigator对象、History对象、Location对象属性和方法

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

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

相关文章

最新Burp Suite入门技术

点击星标&#xff0c;即时接收最新推文 本文选自《web安全攻防渗透测试实战指南&#xff08;第2版&#xff09;》 五折购买链接&#xff1a;u.jd.com/3ibjeF6 Burp Suite的安装 Burp Suite是一款集成化的渗透测试工具&#xff0c;包含了很多功能&#xff0c;可以帮助我们高效地…

word 应用 打不开 显示一直是正在启动中

word打开来显示一直正在启动中&#xff0c;其他调用word的应用也打不开&#xff0c;网上查了下以后进程关闭spoolsv.exe,就可以正常打开word了

Python学习笔记_基础篇(三)_数据类型之列表

一.基本数据类型 整数&#xff1a;int 字符串&#xff1a;str(注&#xff1a;\t等于一个tab键) 布尔值&#xff1a; bool 列表&#xff1a;list &#xff08;元素的集合&#xff09; 列表用[] 元祖&#xff1a;tuple 元祖用&#xff08;&#xff09; 字典&#xff1a;dict 注&a…

中电金信:技术实践|Flink多线程实现异构集群的动态负载均衡

导语&#xff1a;Apache Flink是一个框架和分布式处理引擎&#xff0c;用于对无界和有界数据流进行有状态计算。本文主要从实际案例入手并结合作者的实践经验&#xff0c;向各位读者分享当应用场景中异构集群无法做到负载均衡时&#xff0c;如何通过Flink的自定义多线程来实现异…

LangChain入门:构建LLM驱动的应用程序的初学者指南

LangChain & DemoGPT 一、介绍 你有没有想过如何使用大型语言模型&#xff08;LLM&#xff09;构建强大的应用程序&#xff1f;或者&#xff0c;也许您正在寻找一种简化的方式来开发这些应用程序&#xff1f;那么你来对地方了&#xff01;本指南将向您介绍LangChain&#x…

Jquery 复选框点击生成标签 源代码

html <!DOCTYPE html> <html><head><meta charset"utf-8"><title>服务资源管理</title><link rel"stylesheet" type"text/css" href"../lib/layui/css/layui.css" /><link rel"st…

从零搭建vue + element-plus 项目

目录 从零搭建vue element-plus 项目 环境安装 安装项目 安装命令如下&#xff1a; 选择配置如下&#xff1a; 安装插件与启动服务 安装element框架 使用element框架 测试element是否安装成功 环境判断 安装插件 使用插件 配置变量 暴漏变量 测试…

菜单和内容滚动的联动原理及代码

之前写代码有个需求&#xff1a;左侧是一个菜单&#xff0c;右边是内容&#xff0c;点击左侧菜单右边内容滚动到对应位置&#xff0c;右边内容滚动到某位置时&#xff0c;左侧菜单也会选中对应的菜单项。UI如下&#xff1a;这是大多网站的移动端都会有的需求。 解决方案一&…

Presto之Union算子的实现

一. 前言 在Presto中&#xff0c;Union的算子包括自动去重的Union操作和不去重的Union All操作。本文主要简述在Presto中Union All算子是如何实现和Union算子中是如何实现数据去重的。 二. Presto之Union的实现 1. 首先在g4中将sql的union关键词与setOperation进行绑定 2. AstB…

css 利用 linear-gradient 实现条纹背景

1. 水平条纹背景 当给背景设置渐变效果时&#xff0c;默认的渐变方向是垂直由上到下的&#xff0c;效果如下&#xff1a; {background: linear-gradient(#aaa, #ddd);} 尝试拉近色标的距离&#xff0c;会发现渐变区域变小了&#xff1a; {background: linear-gradient(#aaa 40…

Spring Security6 最新版配置该怎么写,该如何实现动态权限管理

Spring Security 在最近几个版本中配置的写法都有一些变化&#xff0c;很多常见的方法都废弃了&#xff0c;并且将在未来的 Spring Security7 中移除&#xff0c;因此又补充了一些新的内容&#xff0c;重新发一下&#xff0c;供各位使用 Spring Security 的小伙伴们参考。 接下…

Android控件【Notification】

文章目录 Notification与NotifactionManager创建一个NotificationManager使用Builder构造器来创建Notification对象 NotificationChannel通知重要程度设置&#xff0c;NotificationManager类中 Notification&#xff08;通知&#xff09;常见方法说明注意项目结构主要代码 Noti…

国产DSP,经典之作,C2000,QX320F280049

特性&#xff1a; 1、替代TI 的 TMS320F280049 2、独立双核&#xff0c;主频400MHz 3、单精度浮点运算&#xff0c;三角函数运算 4、Flash 1MB&#xff0c;SRAM 1MB 5、12bit ADC&#xff0c;采样率 3.45MSPS 6、16个高分辨率 ePWM 优点&#xff1a; 1、主频400MHz&#xff0c…

clion2020.3配置clang-format

标题clion 启用clang-format 文件->设置->编辑器->代码样式. 为了保持原有代码风格不变&#xff0c;可以把原始的配置风格先导出&#xff0c;最好直接保存到自己的工程下&#xff0c;.clang-format是隐藏文件&#xff0c;需要用ctrlH才能看到 文件->设置->编辑…

i++和++i在操作数栈和局部变量表的分配

1、执行运算指令时&#xff0c;压入操作数栈的顺序不受运算优先级影响 2、i 先将i值压入到操作数栈&#xff0c;再在局部变量表自增 3、i 先在局部变量表自增&#xff0c;再压入到操作数栈 记忆方法&#xff1a;i的先后&#xff0c;表示压入操作数栈的先后。 看如下例子&am…

从零实战SLAM-第七课(多视角几何)

在七月算法报的班&#xff0c;老师讲的蛮好。好记性不如烂笔头&#xff0c;关键内容还是记录一下吧&#xff0c;课程入口&#xff0c;感兴趣的同学可以学习一下。 --------------------------------------------------------------------------------------------------------…

Centos7 开机时遇到initramfs-xxx.img not found错误导致虚拟机无法开启问题处理

1、背景 一台运行在Esxi上面的VM重启后报initramfs-xxx.img not found错误。 按任意键后出现以下错误。 之前在运维Centos7的时候解决过Kernel panic - not syncing : VFS: Unable to mount root fs on unknown-block(0.0)错误&#xff0c;以为按照之前的解决方案&#xff0c;…

【删除vlan的方法】

提示错误 [SW1]undo vlan 10 Error: The VLAN has a L3 interface. Please delete it first. 解决办法 undo interface Vlanif10 #删除vlan 10下的接口 [SW1-GigabitEthernet0/0/1]dis this #删除下列的IP

vue3+ts使用antv/x6 + 自定义节点

使用 2.x 版本 x6.antv 新官网: 安装 npm install antv/x6 //"antv/x6": "^2.1.6",项目结构 1、初始化画布 index.vue <template><div id"container"></div> </template><script setup langts> import { onM…

从鲁大师十五年,寻找软件的生存法则

千禧之年&#xff0c;国内互联网用户数量首次突破1000万大关&#xff0c;互联网的腾飞正式拉开序幕。 从彼时算起&#xff0c;中国互联网发展也不过23年&#xff0c;而我们记忆中那个摇着蒲扇的老头&#xff0c;却占据了其中关键的十五年。 这十五年中有太多曾经为人熟知的软件…