Javascript中的Bom

写在前面

相信学习前端的小伙伴应该都知道Javascript可以简单的分成两个部分,一个是JS基础的ECMAScript和WebAPI的Dom和Bom,相信很多初学的小伙伴都对WebAPI的Dom很熟悉,毕竟Dom的操作确实会更频繁一些,主要是对文档对象的操作;现对来说,而Bom的操作会更少一些(至少我本人是这样)。所以常常会忘记Bom的各种方法与内容,因此,写一篇Bom的基础文章让大家能够参考学习同时自己也能查阅;和小伙伴们共同学习进步。

Bom

Bom定义

  • 提供了独立于内容而与浏览器窗口进行交互的对象,Bom由一系列的对象构成的,并且每一个对象都提供了方法和属性,由于缺乏标准,所以兼容有很多的问题。

window对象

  • window对象是浏览器的顶级对象

    • window对象是一个全局对象,定义在全局的变量、函数都会变成window对象的属性和方法
    • 调用它的方法的时候可以省略掉window的书写
  • window对象的常见事件

    • 窗口加载事件

      • window.onload = function() {} 或者 window.addEventListener('load',function() {})

        1. 作用:当文档内容(图像、css、html)加载完成才会执行,所以可以把它放到文档任何地方,实现<script>的位置任意化
        2. Tip: window.onload这种写法是只能写一次,如果写多个后面的会覆盖前面的onload函数,而用addEventListener就可以写多次‘;但是addEventListener是有兼容要求的
      • docunment.addEventListener('DOMContentLoaded',funcition() {})

        ​ 1.区别:load事件是等页面全部加载完成以后,包含页面的图片、iframe等等;而使用DOMContentLoaded则是Dom加载完成,不包含Dom元素得加载即可运行,所以他的速度会更加快,但是有兼容要求,ie浏览器要ie9以上。

    • 调整窗口大小事件

      • window.onresize = function() {};或者window.addEventListener('resize',function() {})
      • 作用:只要窗口得大小发生变化,每一像素就会触发一次这个事件;可以用它和window.innerWidth(获得当前屏幕宽度)来完成对响应式布局。
    • 窗口打开

      • window.open()方法可以导航到一个特定的URL,也可以打开一个新的浏览器窗口。这个方法可以接收4个参数
    • 对话框弹出

      • alert():弹出系统对话框通常为警告的作用,弹出的弹框只有一个确认按钮
      • confirm():弹出一个对话框有确认的作用,通常有两个按钮(确认和取消)
      • prompt():弹出一个提示框,会让用户输入文本,包含输入域和两个按钮

定时器对象

  • setTimeout(回调函数,几毫秒后执行)
    • 由于页面中常常会有定时器,我们经常给定时器起名字(标识符),为了区分每一个定时器,可以在定时器执行之前一般要清理之前的定时器,避免定时器的效果叠加造成的问题
    • 第一个参数就是常说的回调函数,所谓的回调函数在这里简单理解就是需要一定条件才去触发的函数;比如onclick的函数也是一个回调函数
  • setInterval(回调函数,几毫秒后执行)
    • 这个函数和之前的setTimeout的区别就是,这个函数是隔指定的时间调用一次回调函数,而那个则是只调用一次
  • clearTimeout()/clearInterval():清理定时器,它的参数是我们给定时器起的名字,也就是定时器的ID值

location对象

  • window对象提供了loaction对象用于获取或者设置窗体的地址

  • window对象的属性和方法

    • location.href():获取或设置整个URL
    • location.host():返回主机名
    • location.search():返回参数,也就是地址栏中?后面的所有内容
    • location.port():返回端口号
    • location.assign():跟href一样,可以跳转页面,但是会记录原来的页面,浏览器的回退功能可以实现
    • location.replace():可以跳转但无法后退,推荐使用,跳转的url会替换浏览器历史记录中当前显示的也页面
    • location.reload():重新加载页面
    • loaction.hash():返回哈希地址(也就是地址中#后面跟零个或者多个字符串)

history对象

  • 用于和浏览器的历史记录进行交互,包含用户访问过的URL,也就是保存着用户的上网历史记录,从窗口被打开的那一刻开始计算起。

  • 属性和方法

    • history.back():可以后退功能
    • history.forward():可以前进功能
    • history.go(参数):前进或者后退的功能,参数为“1”前进一页;参数为“-1”后退一页
    • length属性:保存着历史记录的数量,这个数量包括所有的向后和向前的记录
  • 由于是window对象的属性所以每个浏览器窗口、标签页乃至每个框架都有自己的history

navigator对象

  • 主要用于获取浏览器的主要信息,有很多的属性;比较常用的有:

    属性和方法 说明
    userAgent 浏览器用户代理字符串
    cookieEnabled 表示cookie是否启用
    language 浏览器的主语言

Bom和Dom的区别

  1. 首先二者操作的对象不同,Dom(文档对象模型)从翻译我们就可以看出这是一个基于文档对象的应用程序接口,也就是说我们用到的方法“存在”这个对象里面的,我们使用的时候是在调用这个对象下的方法;举个简单的栗子:根据ID获取元素:Document.getElementById();从这我们就可以看出这个是基于文档对象的。所以被用来操作文档,说的通俗一点就是用来操作HTML和XML的。

    而Bom(浏览器对象模型)顾名思义;就是基于浏览器对象的,我们上面提到的对象和方法就都是基于浏览器的操作。同样我们可以从他的调用方法看出来;举个栗子:获取地址栏地址:window.localtion.href;不过常常在我们编写代码的时候是可以把window给省略的,因为默认会带上window对象。

  2. 其次,二者的关系是包含的关系,Docunment的对象是window对象的下的其中一个对象,从window.document就可以看出,DOM的最根本的对象是BOM的window对象的子对象。

  3. Dom的标准是唯一的,遵循的是W3C的标准;而Bom的标准并不唯一,有各个浏览器厂商决定

Tip:每个字都是自己手敲的噢,如果有错别字还请多多包涵,觉得有用的话点个赞支持一下吖~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350