前端学习第二十七更

                                        BOM和DOM


BOM(Browser Object Model): 浏览器对象模型

BOM(Browser Object Model): 浏览器对象模型

其实就是操作浏览器的一些能力

我们可以操作哪些内容:

- 获取一些浏览器的相关信息(窗口的大小)

- 操作浏览器进行页面跳转

- 获取当前浏览器地址栏的信息

- 操作浏览器的滚动条

- 浏览器的信息(浏览器的版本)

- 让浏览器出现一个弹出框(alert/confirm/prompt)

BOM 的核心就是 window 对象

window 是浏览器内置的一个对象,里面包含着操作浏览器的方法

1、获取浏览器窗口的尺寸

innerHeight和innerWidth

这两个方法分别是用来获取浏览器窗口的宽度和高度(包含滚动条的)

2、浏览器的弹出层

alert是在浏览器弹出一个提示框

confirm是在浏览器弹出一个询问框

prompt是在浏览器弹出一个输入框

3、浏览器的地址信息

在window 中有一个对象叫做location 

就是专门用来存储浏览器的地址栏内的信息的

location.href

location.href这个属性存储的是浏览器地址栏内url 地址的信息

location.href这个属性也可以给他赋值

location.reload

location.reload()这个方法会重新加载一遍页面,就相当于刷新是一个道理

(注意:不要写在全局,不然浏览器就会一直处在刷新状态)

4、浏览器的历史记录

window 中有一个对象叫做 history 

是专门用来存储历史记录信息的

history.back

history.back是用来会退历史记录的,就是回到前一个页面(前提要有历史记录)

history.forword

history.forword是去到下一个历史记录里面,也就是去到下一个页面

5、浏览器的版本信息(了解)

window 中有一个对象叫做 navigator

是专门用来获取浏览器信息的

navigator.userAgent

navigator.userAgent是获取的浏览器的整体信息

navigator.appName

navigator.appName获取的是浏览器的名称

navigator.appVersion

navigator.appVersion获取的是浏览器的版本号

navigator.platform

navigator.platform获取到的是当前计算机的操作系统

6、浏览器的onload 事件

这个不在是对象了,而是一个事件

是在页面所有资源加载完毕后执行的

7、浏览器的onscroll 事件

这个onscroll 事件是当浏览器的滚动条滚动的时候触发

或者鼠标滚轮滚动的时候出发(注意:前提是页面的高度要超过浏览器的可是窗口才可以)

[if !supportLists]8、[endif]浏览器滚动的距离

不是用window 对象,而是使用 document 对象

scrollTopscrollLeft

获取的是页面向上(左)滚动的距离

一共有两个获取方式

document.body.scrollTop

document.documentElement.scrollTop

区别:

IE 浏览器

没有DOCTYPE声明的时候,用这两个都行

有DOCTYPE声明的时候,只能用document.documentElement.scrollTop

Chrome 和 FireFox

没有DOCTYPE声明的时候,用document.body.scrollTop

有DOCTYPE声明的时候,用document.documentElement.scrollTop

Safari

两个都不用,使用一个单独的方法window.pageYOffset

9、定时器

在js里面,有两种定时器,倒计时定时器和间隔定时器

倒计时定时器

倒计时多少时间以后执行函数

语法:setTimeout(要执行的函数,多长时间以后执行)(单位毫秒)

会在你设定的时间以后,执行函数

间隔定时器

每间隔多少时间就执行一次函数

语法:setInterval(要执行的函数,间隔多少时间)

定时器的返回值

设置定时器的时候,他的返回值是部分setTimeout和setInterval的

只要有一个定时器,那么就是一个数字

关闭定时器

我们刚才提到过一个timerId,是表示这个定时器是页面上的第几个定时器

这个timerId 就是用来关闭定时器的数字

我们有两个方法来关闭定时器clearTimeout和clearInterval

DOM(Document Object Model): 文档对象模型

getElementById

getElementById是通过标签的id 名称来获取标签的

因为在一个页面中id 是唯一的,所以获取到的就是一个元素

getElementsByClassName

getElementsByClassName是用过标签的class 名称来获取标签的

因为页面中可能有多个元素的class 名称一样,所以获取到的是一组元素

哪怕你获取的class 只有一个,那也是获取一组元素,只不过这一组中只有一个 DOM 元素而已

( 获取到的是一组元素,是一个长得和数组一样的数据结构,但是不是数组,是伪数组

这个一组数据也是按照索引排列的,所以我们想要准确的拿到这个div,需要用索引来获取)

getElementsByTagName

getElementsByTagName是用标签的标签名称来获取标签的

因为页面中可能有多个元素的标签名称一样,所以获取到的是一组元素

哪怕真的只有一个这个标签名,那么也是获取一组元素,只不过这一组中只有一个DOM 元素而已

querySelector

querySelector是按照选择器的方式来获取元素

也就是说,按照我们写css 的时候的选择器来获取

这个方法只能获取到一个元素,并且是页面中第一个满足条件的元素

querySelectorAll

querySelectorAll是按照选择器的方式来获取元素

这个方法能获取到所有满足条件的元素,以一个伪数组的形式返回

10、操作属性

通过我们各种获取元素的方式获取到页面中的标签以后

我们可以直接操作DOM 元素的属性,就能直接把效果展示在页面上

innerHTML

获取元素内部的HTML 结构

设置元素的内容

innerText

获取元素内部的文本(只能获取到文本内容,获取不到html 标签)

可以设置元素内部的文本

getAttribute

获取元素的某个属性(包括自定义属性)

setAttribute

给元素设置一个属性(包括自定义属性)

removeAttribute

直接移除元素的某个属性

style

专门用来给元素添加css 样式的

添加的都是行内样式

className

专门用来操作元素的类名的

也可以设置元素的类名,不过是全覆盖式的操作

在设置的时候,不管之前有没有类名,都会全部被设置的值覆盖

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

推荐阅读更多精彩内容