首页 > 编程语言 >JavaScriptBOM操作

JavaScriptBOM操作

时间:2024-10-21 10:01:14浏览次数:1  
标签:function JavaScriptBOM log console window 操作 浏览器 history

认识BOM操作

◼ BOM:浏览器对象模型(Browser Object Model)
    简称BOM,由浏览器提供的用于处理文档(document)之外的所有内容的其他对象;
    比如navigator、location、history等对象;
◼ JavaScript有一个非常重要的运行环境就是浏览器
    而且浏览器本身又作为一个应用程序需要对其本身进行操作;
    所以通常浏览器会有对应的对象模型(BOM,Browser Object Model);
    我们可以将BOM看成是连接JavaScript脚本与浏览器窗口的桥梁;
◼ BOM主要包括一下的对象模型:
    window:包括全局属性、方法,控制浏览器窗口相关的属性、方法;
    location:浏览器连接到的对象的位置(URL);
    history:操作浏览器的历史;
    navigator:用户代理(浏览器)的状态和标识(很少用到);
    screen:屏幕窗口信息(很少用到)

全局对象window

◼ window对象在浏览器中可以从两个视角来看待:
  视角一:全局对象。
    ✓ 我们知道ECMAScript其实是有一个全局对象的,这个全局对象在Node中是global;
    ✓ 在浏览器中就是window对象;
  视角二:浏览器窗口对象。
    ✓ 作为浏览器窗口时,提供了对浏览器操作的相关的API;
◼ 当然,这两个视角存在大量重叠的地方,所以不需要刻意去区分它们:
  事实上对于浏览器和Node中全局对象名称不一样的情况,目前已经指定了对应的标准,称之为globalThis,并且大多数现代
  浏览器都支持它;
  放在window对象上的所有属性都可以被访问;
  使用var定义的变量会被添加到window对象中;
  window默认给我们提供了全局的函数和类:setTimeout、Math、Date、Object等;

window对象的作用

◼ 事实上window对象上肩负的重担是非常大的:
  第一:包含大量的属性,localStorage、console、location、history、screenX、scrollX等等(大概60+个属性);
  第二:包含大量的方法,alert、close、scrollTo、open等等(大概40+个方法);
  第三:包含大量的事件,focus(聚焦)、blur(失去焦点)、load(文档加载)、hashchange(哈希值改变)等等(大概30+个事件);
  第四:包含从EventTarget继承过来的方法,addEventListener、removeEventListener、dispatchEvent方法;
◼ 那么这些大量的属性、方法、事件在哪里查看呢?
  MDN文档:
  https://developer.mozilla.org/zh-CN/docs/Web/API/Window
◼ 查看MDN文档时,我们会发现有很多不同的符号,这里我解释一下是什么意思:
  删除符号:表示这个API已经废弃,不推荐继续使用了;
  点踩符号:表示这个API不属于W3C规范,某些浏览器有实现(所以兼容性的问题);
  实验符号:该API是实验性特性,以后可能会修改,并且存在兼容性问题;

window.open/window.close

<!-- 案例 -->
// window..close 只能关闭由window.open打开的新窗口

  var opent = document.querySelector("button")
  var closeEls = document.querySelectorAll("button")
  var closeEl = closeEls[1]
  var body = document.body
  console.log(close)
  opent.onclick=function(){
    // 打开一个新的网页//"_self":在自己的页面打开
  window.open("./new.html","_blank")
  }
  closeEl.onclick = function(){
    window.close()
  }

window常见的属性

<!-- 浏览器高度 -->
  console.log(window.outerHeight)
  console.log(window.innerHeight)
<!-- 浏览器窗口距离屏幕的距离 -->
  console.log(window.screenX)
  console.log(window.screenY)
<!-- 监听 -->
  window.addEventListener("scroll",function(){
    console.log(window.scrollX)
    console.log(window.scrollY)
  })

window常见的方法

<!-- close 关闭窗口方法 -->

  const closeBtn = document.querySelector("button")
  closeBtn.onclick=function(){
    close()
  }
  <!-- scrollTo 滚动到一组特定的 坐标。-->

  const scrollToBtn = document.querySelector("button")
  scrollToBtn.onclick = function(){
    scrollTo({top:100})
  }
  <!-- open/close 打开或关闭-->

  // window..close 只能关闭由window.open打开的新窗口
  var opent = document.querySelector("button")
  var closeEls = document.querySelectorAll("button")
  var closeEl = closeEls[1]
  var body = document.body
  console.log(close)
  opent.onclick=function(){
    // 打开一个新的网页//"_self":在自己的页面打开
  window.open("./new.html","_blank")
  }
  closeEl.onclick = function(){
    window.close()
  }

window常见的事件

  <!-- focus窗口获取到焦点 -->
  window.onfocus = function(){
  console.log("窗口获取到焦点")
  }
  <!-- blur窗口失去焦点 -->
  window.onblur = function(){
    console.log("窗口失去焦点")
  }
  <!-- load 页面加载完成-->
  // 整个页面加载完成
  window.onload = function(){
    console.log("页面加载完成")
  }
  // hash改变
  const hashBtn = document.querySelector("button")
  hashBtn.onclick = function(){
    location.hash = "aaa"
  }
  <!-- hashchange hash被修改-->
  window.onhashchange = function(){
    console.log("hash被修改")
  }

location对象

  ◼ location对象用于表示window上当前链接到的URL信息。

location对象常见的属性

  ◼ 常见的属性有哪些呢?
    href: 当前window对应的超链接URL, 整个URL;
    protocol: 当前的协议;
    host: 主机地址;
    hostname: 主机地址(不带端口);
    port: 端口;
    pathname: 路径;
    search: 查询字符串;
    hash: 哈希值;
    username:URL中的username(很多浏览器已经禁用);
    password:URL中的password(很多浏览器已经禁用);

Location对象常见的方法

  ◼ location有如下常用的方法:
    assign:赋值一个新的URL,并且跳转到该URL中;
    replace:打开一个新的URL,并且跳转到该URL中(不同的是不会在浏览记录中留下之前的记录);
    reload:重新加载页面,可以传入一个Boolean类型;
  案例:
    // location方法
      var btnEls =document.querySelectorAll("button")
      btnEls[0].onclick = function(){
        <!-- 有返回按钮 -->
        location.assign("http://www.baidu.com")
      }
      btnEls[1].onclick = function(){
        <!-- 没有返回按钮 -->
        location.replace("http://www.baidu.com")
      }
      btnEls[2].onclick = function(){
        <!-- 刷新网页 -->
        location.reload()
      }

URLSearchParams

  ◼ URLSearchParams 定义了一些实用的方法来处理URL 的查询字符串。
      可以将一个字符串转化成URLSearchParams类型;
      也可以将一个URLSearchParams类型转成字符串;
  <!-- 案例 -->
  var URLSearchString = "?name=hdc&age=18&height=1.88"
  <!-- 方法一 -->
  console.log(URLSearchString.split("&"))
  <!-- 方法二 -->
  var searchParams = new URLSearchParams(URLSearchString)
  console.log(searchParams)
  console.log(searchParams.get("name"))
  console.log(searchParams.get("age"))
  console.log(searchParams.get("height"))
  searchParams.append("address","天津市")
  console.log(searchParams.get("address"))
  // 转换成字符串
  console.log(searchParams.toString())
  ◼ URLSearchParams常见的方法有如下:
      get:获取搜索参数的值;
      set:设置一个搜索参数和值;
      append:追加一个搜索参数和值;
      has:判断是否有某个搜索参数;
      https://developer.mozilla.org/zh-CN/docs/Web/API/URLSearchParams
  ◼ 中文会使用encodeURIComponent和decodeURIComponent进行编码和解码
      // 编码
      encodeURIComponent()
      // 解码
      decodeURIComponent()

history对象

history对象常见属性和方法

  ◼ history对象允许我们访问浏览器曾经的会话历史记录。
  ◼ 有两个属性:
    length:会话中的记录条数;
    state:当前保留的状态值;
  ◼ 有五个方法:
    back():返回上一页,等价于history.go(-1);
    forward():前进下一页,等价于history.go(1);
    go():加载历史中的某一页;
    pushState():打开一个指定的地址;
    replaceState():打开一个新的地址,并且使用replace;
  ◼ history和hash目前是vue、react等框架实现路由的底层原理,具体的实现方式我会在后续讲解。
   // 1.history对应的属性
    console.log(history.length)
    console.log(history.state)

    document.querySelector("button").onclick = function(){
      // 添加一个新的历史
      history.pushState({name:"hdc",age:18},"",'/hdc')
      console.log(history.length)
      console.log(history.state)
    }
    document.querySelectorAll("button")[1].onclick = function(){
      // 返回上一个历史
      history.back()
      history.forward()
      // forward()前进两次
      // history.go(2)
      // back()后退两步
      // history.go(-2)
    }
    <!-- 替换路径 -->
    document.querySelectorAll("button")[2].onclick = function(){
      history.replaceState({age:21,name:"hdc"},"","/webKing")
    }
◼ navigator 对象表示用户代理的状态和标识等信息。

screen

◼ screen主要记录的是浏览器窗口外面的客户端显示器的信息:
  比如屏幕的逻辑像素screen.width、screen.height;

标签:function,JavaScriptBOM,log,console,window,操作,浏览器,history
From: https://www.cnblogs.com/hdc-web/p/18488415

相关文章

  • JavaScript的DOM操作
    元素的继承classStudentextendsPerson{}创建一个Student对象继承自Person对象本身会自带Person的属性并且可以创建属于自己的属性什么是DOM?◼前面我们花了很多时间学习JavaScript的基本语法,但是这些基本语法,但是这些语法好像和做网页没有什么关系,和前面学习的H......
  • 2024-10-19:用go语言,给定一个正整数 k 和初始数组 nums = [1], 可以执行两种操作:将数组
    2024-10-19:用go语言,给定一个正整数k和初始数组nums=[1],可以执行两种操作:将数组中任一元素加一,或复制数组中任意元素并将其附加到数组末尾。求使得数组元素之和大于或等于k所需的最少操作次数。输入:k=11。输出:5。解释:可以对数组nums=[1]执行以下操作:将元......
  • 操作系统学习笔记-1.2操作系统的发展历程,运行机制
    文章目录批处理操作系统1.**单道(Single-ProgrammedSystem)**特点:举例:2.**多道(Multi-ProgrammingSystem)**特点:3.**单道与多道的对比**分时操作系统与实时操作系统1.**分时操作系统(Time-SharingOperatingSystem)**概念:特点:应用场景:举例:2.**实时操作系统(Real-Tim......
  • MySQL5.7 InnoDB在线DDL操作
    MYSQL官方文档:https://dev.mysql.com/doc/refman/5.7/en/innodb-online-ddl.html目录在线DDL原理在线DDL支持情况IndexOperations(索引操作)PrimaryKeyOperations(主键操作)ColumnOperations(列操作)TableOperations(表操作)pt-osc方式在线DDL和pt-osc对比参考在线DDL原理MySQL5.6......
  • KeyShot基础操作5 - 动画篇
    --本篇导航--动画界面动画类型动画时间轴导出动画一些例子注:本人目前只会简单的动画,摄像机运镜、速度曲线这些还控制不好。以下均为简单演示。动画界面KeyShot中的动画每次只能是一个动作,如果需要对同一个对象创建复杂的动画,就需要对其多次添加不同的动画效果。做......
  • 文件的基本操作
    创建文件删除文件在这里我们可以看到,删除文件这个系统调用也是需要用文件名去目录表中寻找文件的打开文件当用户对一个文件实施多次读/写等操作时,每次都要从检索目录开始.为了避免多次重复地检索目录,大多数操作系统要求,当用户首次对某文件发出操作请求时,须先利用系统调用......
  • 实验报告3-数据库框架实现数据操作1
    资源下载  实验报告3-数据库框架实现数据操作1一、实现思路        使用SpringBoot整合MyBatis-Plus完成开支分析案例的后台数据整合功能。要求:        1、根据静态页面的echarts数据,设计返回前端数据包装类CategoryVo。        2、多表关......
  • 二分求操作后的最大最小中位数
    这类题是让你求对序列进行一系列操作之后的最小/最大中位数求最小中位数二分最小中位数,显然二分要符合mid越大越对,边界才能向下收缩。对于这个条件,我们选择计算小于等于当前mid的数才是对的,因为这样显然mid越大cnt越大,而符合这个条件,我们就不断收缩上界,直到达到第......
  • PbootCMS您的账号权限不足,您无法执行该操作!
    在PBootCMS中,如果您遇到“您的账号权限不足,您无法执行该操作!”的提示,通常是因为当前登录的管理员账号没有足够的权限来执行某些操作。以下是一些解决方法,帮助您提升账号权限或添加新管理员并赋予相应权限:方法一:通过数据库修改权限备份数据库:在进行任何数据库操作之前,务必......
  • 2.1.2 话题通信基本操作A(C++)
    需求:编写发布订阅实现,要求发布方以10HZ(每秒10次)的频率发布文本消息,订阅方订阅消息并将消息内容打印输出。分析:在模型实现中,ROSmaster不需要实现,而连接的建立也已经被封装了,需要关注的关键点有三个:发布方接收方数据(此处为普通文本)流程:编写发布方实现;编写订阅......