一.初识DOM

1.什么是DOM?为什么学习DOM

2.DOM是实现js在网页实现交互的关键环节,我们的js代码就是通过DOM的方法来实现对于html内容的操作。

3.认识DOM实现了js和网页结合的原理;

4.认识DOMTREE;认识DOM的分类;

5.简单获取元素,简单事件绑定;

6.认识DOM,js,html,所运行的环境BOM;

#二.BOM简介:Browser Object Model

**1. Bom ** 是什么?

由浏览器实现的供JavaScript程序调用的一组对象

2. **Bom ** 的组成部分?

\1. Window对象表示当前浏览器窗口,是Bom的核心

\2. document对象表示当前页面文档相关信息

\3. location对象表示当前窗口地址栏相关信息

\4. history对象表示当前浏览器历史记录相关信息

\5. screen对象表示客户端屏幕相关信息

\6. navigator对象表示浏览器自身相关信息

\7. Event事件集合

#三.Window对象

所有在全局声明的变量和函数,自动成为window对象的属性和方法

#四.location对象

\1. location.href 获取或设置地址栏完整路径

\2. location.search 获取地址栏?后的参数信息

\3. location.hash 获取地址栏#后的参数信息

\4. location.reload() 刷新页面

#五.history对象

\1. history.go(n) n正数:返回历史纪录后n页 ; n负数:返回历史记录前n页 ; n为0相当于刷新页面

\2. history.back() 返回上一页

\3. history.forword() 返回下一页

#六.课堂案例

#1. 打字机

效果图

img

功能思路分析:

\1. 点击开始打字按钮实现打字效果

\2. 利用间歇调用定时器每隔一段时间打一个字(setIntelval)

\3. 当所有的字打完后停止打字(根据下标判断)

\4. 打字没有结束不能重复点(disabled禁用)

img

#2. 验证码倒计时

效果图

img

功能思路分析:

\1. 点击获取验证码按钮实现验证码倒计时

\2. 利用间歇调用定时器每隔一秒执行一次(setInterval)

\3. 当倒计时由初始值减到0时定制倒计时,恢复默认(根据初始值判断)

\4. 倒计时没有结束不能重复点击(disabled)

#3. 倒计时

效果图

img

功能思路分析:

\1. 创建一个未来时间,获取时间戳

\2. 在定时器中创建一个当前时间获取时间戳

\3. 未来时间-当前时间拿到时间差,

\4. 将时间差转换为天时分秒输出到页面

#4. 抽奖

效果图

功能思路分析:

\1. 点击抽奖按钮显示抽奖过程(setInterval)

\2. 5秒后停止抽奖(setTimeout)

\3. 停止后显示抽中奖品并从奖品数组中删除抽中的奖品( splice() )

\4. 限制抽奖次数( 计数器 )

#七.今日小结

间歇调用定时器:setInterval( function(){}, 毫秒数 ) clearInterval( 定时器名 )

超时调用定时器:setTimeout( function(){}, 毫秒数 ) clearTimeout( 定时器名 )

按钮禁用:元素.disabled

地址栏相关信息:location.href location.search

#八.作业 -- 炫彩点名器

效果图

功能点:

\1. 创建一个名单数组,将数组中的数据利用**map().join(‘’)**渲染到页面

\2. 点击开始点名按钮,显示抽奖过程(setInterval),过程中每一个li颜色随机变化

\3. 5秒后**(setTimeout)**从名单中随机(封装随机函数)点中一人高亮显示(加背景色)。

\4. 抽奖过程中按钮禁用(disabled)

#九.数组迭代方法(扩展)

#语法:

arr.forEach(function( item,index,arr){

**//item ** : 数组中的每一项

//index: 每一项对应的下标

**//arr ** 数组本身

});

#1. forEach()

相当于普通的for循环,没有返回值

#2. map()

得到每一项的返回结果组成的数组

#3. filter()

筛选出返回条件为真的项组成的数组

#4. some()

数组中只要有一项为真就返回true

img

#5. every()

数组中所有项为真就返回true,否则返回false

img

js下 Day01、DOM对象,BOM浏览器对象模型的更多相关文章

  1. js 中的 DOM 和 BOM

    BOM浏览器对象模型   概念:Browser Object Model   组成:   Window:浏览器窗口对象   Navigator:浏览器对象   screen:显示器屏幕对象   His ...

  2. 第一百一十一节,JavaScript,BOM浏览器对象模型

    JavaScript,BOM浏览器对象模型 学习要点: 1.window对象 2.location对象 3.history对象 BOM也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能.BOM ...

  3. JavaScript——BOM(浏览器对象模型),时间间隔和暂停

    BOM(浏览器对象模型):能够对浏览器的窗体进行訪问和操作 1.主要的BOM体系: window------------document-------------------------------- ...

  4. 前端(十六)—— JavaScript盒子模型、JS动画、DOM、BOM

    JS盒子模型.JS动画.DOM.BOM 一.JS盒模型 1.width | height parseInt(getComputedStyle(ele, null).getPropertyValue(' ...

  5. js中的DOM对象 和 jQuery对象 比较

    一,二者的区别 通过 jQuery 获取的元素是一个数组,数组中包含着原生JS中的DOM对象. 总结:jQuery 就是把 DOM 对象重新包装了一下,让其具有了 jQuery 方法. 二,二者的相互 ...

  6. js中的DOM对象和jQuery对象的比较

    1. 二者的不同之处: 通过jQuery获取的元素是一个数组, 数组中包含着原生JS中的DOM对象. 例如, 针对下面的一个div结构: <div id="Box">& ...

  7. JavaScirpt(JS)——BOM浏览器对象模型

    一.BOM概念 BOM(Browser Object Model)即浏览器对象模型.可以对浏览器窗口进行访问和操作.使用 BOM,开发者可以移动窗口.改变状态栏中的文本以及执行其他与页面内容不直接相关 ...

  8. JS第三部分--BOM浏览器对象模型

    一.client系列:宽高边框 二.offset系列:偏移 三.scroll系列 四.BOM的介绍 4.1.打开新窗口 4.2.location对象(本地信息对象) 4.3.history对象 4.4 ...

  9. js BOM浏览器对象模型

    BOM即Browser Object Model,浏览器对象模型,表示浏览器窗口,所有js全局对象.函数以及变量均是window 对象的成员. 对于不同的浏览器,表示宽度和高度的方法不同: 对于IE9 ...

随机推荐

  1. MindManager 2021 版新增了哪些功能

    MindManager Windows 21是一款强大的可视化工具和思维导图软件,在工作应用中有出色的表现.今天就带大家来看下这个新版本增加了哪些功能? 1.新增现代主题信息样式MindManager ...

  2. HMM、CTC、RNN-T训练是所有alignment的寻找方法

    1.1 LAS产生label的计算   LAS是可以看做能够直接计算给定一段acoustic feature时输出token sequences的概率,即\(p(Y|X)\),LAS每次给定一个aco ...

  3. 【ACwing 100】InDec序列——差分

    (题面来自AcWing) 给定一个长度为 n 的数列 a1,a2,-,an,每次可以选择一个区间 [l,r],使下标在这个区间内的数都加一或者都减一. 求至少需要多少次操作才能使数列中的所有数都一样, ...

  4. 肝了75天,五万五千字,《Spring Boot 进阶》专栏文章整理成册,分享~

    前言 Spring Boot 这个专栏从早期的体系构建到写完,总共花费了七十五天,期间由于工作及个人原因停更了一段时间,没办法,工作实在太忙了. 很多人疑惑了,为什么源码介绍过了就结束了?高级的部分不 ...

  5. 真香!Python开发工程师都选择这个数据库:因为它免费

    数据库类别 既然我们要使用关系数据库,就必须选择一个关系数据库. 目前广泛使用的关系数据库也就这么几种: 付费的商用数据库: Oracle,典型的高富帅: SQL Server,微软自家产品,Wind ...

  6. fist-第五天冲刺随笔

    这个作业属于哪个课程 https://edu.cnblogs.com/campus/fzzcxy/2018SE1 这个作业要求在哪里 https://edu.cnblogs.com/campus/fz ...

  7. 部署完的Django项目升级为HTTPS

    1.阿里云上申请免费ssl证书--->提交各种资料--->等待审核--->下载证书. 2.远程连接阿里云服务器,将下载下来的证书内容复制到Nginx安装目录下的cert目录(需要新建 ...

  8. 第15.47节、PyQt显示部件:QGraphicsView图形视图和QGraphicsScene图形场景简介及应用案例

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 老猿学5G博文目录 一.概述 Designer中的Graphics V ...

  9. PyQt(Python+Qt)学习随笔:QTableWidgetItem项数据的data和setData访问方法

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QTableWidget部件中的QTableWidgetItem项数据可以通过项的data( int ...

  10. 第10章 Python的模块和包

    前面几章介绍的Python基础知识,相关案例都是以单源代码文件为例来说明的,这种单源代码文件在Python中就是模块,每个模块文件都可以被其他应用导入,Python正是通过模块导入技术来实现很灵活的功 ...