【郑州-145期】什么是BOM—补充?


大家好,我是IT修真院郑州分院第三期的学员高雪峰,一枚正直、纯洁、善良的前端程序员

今天给大家分享一下,修真院官网JS(职业)任务4,深度思考中的知识点——BOM

1.背景介绍

Browser Object Model,浏览器对象模型,简称BOM,是JavaScript在使用过程中极其重要的组成部分,也是在浏览器实现JavaScript的核心。多年来,BOM缺少一个比较统一的标准,基本上都是各大浏览器提供商各自为政,对其进行扩展补充。W3C为了把浏览器中的JavaScript最基本部分标准化,已经将BOM的主要方面纳入到了HTML5标准中。接下啦,我们接着上一次多的内容,来认识一下它。

2.知识剖析

2.1什么是间歇调用和超时调用?

Javascript是单线程语言,但允许通过设置超时值和间歇时间值调度代码在特定的时刻执行。

超时调用,在指定时间过后执行代码。需要通过window对象的setTimeout()方法,它接受两个参数:要执行的代码,和以毫秒表示的时间。第一个参数可以是一个包含js代码的字符串,也可以是一个函数。第二个参数是等待多长时间的毫秒数。这里需要注意的是,由于js是单线程语言,因此,当时间到了之后,代码也许并不会如想象的一般,立即执行,它只是表示时间到了以后将要执行的代码放到了js的处理任务的队列中,还要老老实实地排队等候进一步的处理。

//不建议传递字符串!

setTimeout("alert('Hello Da Wa!')", 1000);

//推荐以下写法

setTimeout(function(){

alert('Hello World!')

}, 2000);

//使用清除方法在代码未调用前清除该项,在超时调用之前处理才会生效,超时调用之后执行的话什么也不会改变。

clearTimeout();

间隔调用,在每隔指定时间就执行执行代码,直到间歇调用被取消或者页面被卸载。它需要通过window对象的setInterval()方法,它接受两个参数:要执行的代码,和以毫秒表示的时间。第一个参数可以是一个包含js代码的字符串,也可以是一个函数。第二个参数是间隔多长时间的毫秒数。取消间歇调用的重要性远远大于取消超时调用,防止间歇调用的循环执行。在项目开发中,最好不要使用间歇调用。

//不建议传递字符串!

setInterval("alert('Hello Da Wa!')", 1000);

//推荐以下写法

setInterval(function(){

alert('Hello World!')

}, 2000);

//使用清除方法在代码未调用前清除该项,为防止间隔调用无限循环下去,必须使用这个方法

clearInterval();

2.2 location对象

location对象是BOM对象中有一个极为重要的对象,它也是一个特别的对象。它既是window对象的属性,又是document对象的属性,也就是说,window.location和document.location引用的是同一个对象。

相关链接:w3school(http://www.w3school.com.cn/jsref/dom_obj_location.asp)

location对象可以通过多种方式改变浏览器的位置。最常用的方式是assign(),(assign翻译为分配,选派,归属)。它可以打开一个新的url并在浏览器的历史记录中生成一条记录。使用window.location或者location.href设置一个url值,也会以该值调用assign()方法。

location.assign('http://www.baidu.com');

//以下方法等价于上边的写法

window.location = 'http://www.baidu.com';

location.href = 'http://www.baidu.com';

location对象的其他属性也可以修改url地址,同样会在浏览器的历史记录中生成一条新的记录。用户通过单击“后退”就可以返回前一个页面的地址。如果我们不希望用户再返回去,我们就使用到了replace()这个方法,它接受一个参数——要跳转的url,浏览器位置发生变化,同时,不会和刚刚提到的那几个方法一样,会在历史记录中生成新纪录,因此也就不会返回原有的位置了。

于位置有关的,还有一个方法——reload(),作用是重新加载当前的页面。如果不加任何参数,它就会以最有效的方式进行重新加载,也就是用浏览器缓存进行加载。我们如果想强制网页从服务器端重新加载数据过来,可以提供一个true值。例如:location.reload(true)。

2.3 navigator对象

navigator对象,用于识别客户端浏览器信息,最早由Netscape Navigation 2.0引入。浏览器各自可能也有自有的识别客户端信息的对象或者方法,但是navigator对象是所有支持js的浏览器所共有的。

除了识别显示客户端的信息之外,navigator对象也提供了一个检测插件的方法,使用plugins数组。该数组包括以下内容:name(插件的名字)、description(插件的描述)、filename(插件的文件名)、length(插件所处理的MIME类型数量)。

2.4 screen对象

screen对象,在编程过程中使用的频次并不高,是一个比较低调的存在。它用来表述客户端的能力,包括浏览器窗口外部的显示器信息,像素高度和宽度,DPI值,颜色的位数(多为32位)、屏幕的位深等信息。

2.5 history对象

history对象,用于保存用户自打开浏览器时以后的历史记录,是window对象的属性。可以使用go()的方法在历史记录中任意跳转,可以向后也可以向前。这个方法可以接受一个向后或者向前的页面数(整数值)。负值表示向后跳转,正值表示向前跳转。也可以传递一个字符串参数,该字符串必须是浏览器历史记录中存在的,否则无效。

history.go(-1);

history.go(1);

history.go(2);

3.常见问题

问题: 如何使用超时调用的方法,避免间隔调用的问题?

4.解决方案

这里引入《JavaScript高级程序设计》中的一段代码进行解决方案的介绍。这样做的优点是,超时调用可以执行一次自行停止,不存在无限循环执行的情况,不用刻意使用清除的方法对该方法进行处理,比之于间隔调用,不会因为不受限制而出现问题。

var num = 0;

var max = 10;

var a = null;

function old(){

      num++;

//如果执行次数达到了max设定的值,则取消后续尚未执行的调用

      if(num == max){

             clearInterval(a);

             alert("Done");

        }

}

a = setInterval(old, 1000);

//使用超时调用规避间隔调用的循环执行问题

function b(){

        num++;

//如果执行次数未达到max设定的值,则设置另一次超时调用

        if(num < max){

                   setTimeout(b, 1000);

         } else {

                   alert("Done");

          }

}

setTimeout(b, 1000);

5.编码实战

参看上边各知识点简单的demo演示,暂无更多demo!

6.扩展思考

问题: 如何在列表网页,点击页码等条件重新加载数据后,从顶部显示?

这里使用到了location.hash的方法进行处理。

//页面跳转置顶显示,使用以下两行代码

$location.hash('');

$anchorScroll();

7.参考文献

参考一:《JavaScript高级程序设计》

参考二: w3school:http://www.w3school.com.cn/index.html

8.更多讨论

讨论点:大家对于window对象还有哪些认识,分享一下?

PPT:https://ptteng.github.io/PPT/PPT/js-04-bom%20(2).html#/

视频:https://v.qq.com/x/page/r0515qq8isk.html


什么是BOM—补充_腾讯视频

文本链接:http://www.jnshu.com/daily/26200?dailyType=others&total=148&page=1&uid=7446&sort=0&orderBy=3

------------------------------------------------------------------------------------------------------------------------

技能树.IT修真院

“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。

这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧~

你可以直接点击此链接:http://jnshu.com/login/1/84959420

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

推荐阅读更多精彩内容