前端开发之BOM和DOM(转载)
BOM
BOM:是指浏览器对象模型,它使JavaScript可以和浏览器进行交互。
1,navigator对象:浏览器对象,通过这个对象可以判定用户所使用的浏览器,包含了浏览器相关信息。
navigator.appName // Web浏览器全称
navigator.appVersion // Web浏览器厂商和版本的详细字符串
navigator.userAgent // 客户端绝大部分信息
navigator.platform // 浏览器运行所在的操作系统
2,screen对象:屏幕对象,可以获取一些和屏幕相关的信息。
screen.availWidth // 可用的屏幕宽度
screen.availHeight // 可用的屏幕高度
3,history对象:浏览历史对象,包含了用户对当前页面的浏览历史,但我们无法查看具体的地址,可以简单的用来前进或后退一个页面。
history.forward() // 前进一页
history.back() // 后退一页
4,location对象:用于获取浏览器的当前的网页地址,还可以重定向新的地址。
location.href // 获取URL
location.href="URL" // 跳转到指定页面
location.reload() // 重新加载页面
5,弹出框相关方法
1,alert方法:警告框,让用户看到某些信息。
alert("浏览此网页注意个人信息保护!");
2,confirm方法:确认框,用于验证一些用户的选择。
confirm("是否要下载此文件?")
3,prompt方法:提示框,用于接收用户的输入值。
prompt("请在输入你的答案")
6,计时相关方法
1,setTimeout方法:设定多长时间后开始执行一段JavaScript代码。
setTimeout("JavaScript代码",秒数) // 秒数的单位为毫秒
2,clearTimeout方法:取消计时设定。
var t=setTimeout("console.log('哈哈哈')",2000);
clearTimeout(t);
3,setInterval方法:按设定的周期执行一段JavaScript代码。
setInterval("JavaScript代码",时间间隔) // 返回ID值
4,clearInterval方法:取消设定的setInterval()。
clearInterval(setInterval返回的ID值)
DOM
DOM:是指文档对象模型,使用它可以访问HTML文档中的所有元素。
DOM树:DOM规定HTML文档中的每一个元素都是一种节点。
1、document对象:文档节点,代表整个HTML文档
2、element对象:标签节点,代表文档中的标签
3、text对象:文本节点,代表标签中的文本内容
4、attribute对象:属性节点,代表标签中的属性
5、comment对象:注释节点,代表文档中的添加的注释
通过这些对象我们就可以操作HTML文档做出各种动态变化。
1,标签查找
1,直接查找
document.getElementById("id值") // 根据ID获取一个标签
document.getElementsByClassName("类名") // 根据class属性获取
document.getElementsByTagName("标签名") // 根据标签名获取标签合集
2,间接查找
document.parentElement // 父节点标签元素
document.children // 所有子标签
document.firstElementChild // 第一个子标签元素
document.lastElementChild // 最后一个子标签元素
document.nextElementSibling // 下一个兄弟标签元素
document.previousElementSibling // 上一个兄弟标签元素
2,节点操作
1,创建节点:createElement(标签名)
document.createElement("div");
2,添加节点:
// 添加一个子节点
某节点.appendChild(标签名) // 在某节点内的一个节点之前添加一个节点
某节点.insertBefore(标签名,一个节点)
3,删除节点:
// 删除某节点下的一个子节点
某节点.removeChild(要删除的节点)
4,替换节点:
// 替换某节点下的一个子节点
某节点.replaceChild(新节点, 要替换的子节点);
5,节点的文本:
// 获取节点的文本值
某节点.innerHTML // 获取节点的所有的标签以及文本值
某节点.innerText // 只获取节点的文本值 // 设置节点的文本值
某节点.innerHTML = 新的标签和文本值
某节点.innerText = 新的文本值
6,节点的属性:
// 设置节点的属性和值
某节点.setAttribute("属性名","属性值") // 获取节点的属性值
某节点.setAttribute("属性名") // 删除节点的属性
某节点.removeAttribute("属性名") // 标签的自带属性还可以通过 .属性名 来获取和设置
节点.自带属性名
节点.自带属性名=属性值
7,获取节点返回值:
// 适用的标签有:input select textarea
节点.value
8,节点的类的操作:
className // 获取所有样式类名(字符串)
classList.remove() // 删除指定类
classList.add() // 添加类
classList.contains() // 类存在返回true,否则返回false
classList.toggle() //类存在就删除,否则添加
JavaScript操作CSS的属性
1,对于没有中横线的CSS属性一般直接使用style.属性名即可。如:
obj.style.margin
obj.style.width
obj.style.left
obj.style.position
2,对含有中横线的CSS属性,将中横线后面的第一个字母换成大写即可。如
obj.style.marginTop
obj.style.borderLeftWidth
obj.style.zIndex
obj.style.fontFamily
事件
当用户触发某一条件时,浏览器会运行一些JavaScript代码来改变HTML文件的一些属性,从而完成某一件事情,这个条件就是事件。
JavaScript中常用的事件:
onclick 当用户点击某个对象时调用的事件句柄。
ondblclick 当用户双击某个对象时调用的事件句柄。 onfocus 元素获得焦点。
onblur 元素失去焦点。 应用场景:用于表单验证,用户离开某个输入框时,代表已经输入完了,我们可以对它进行验证.
onchange 域的内容被改变。 应用场景:通常用于表单元素,当元素内容被改变时触发.(select联动) onkeydown 某个键盘按键被按下。 应用场景: 当用户在最后一个输入框按下回车按键时,表单提交.
onkeypress 某个键盘按键被按下并松开。
onkeyup 某个键盘按键被松开。
onload 一张页面或一幅图像完成加载。
onmousedown 鼠标按钮被按下。
onmousemove 鼠标被移动。
onmouseout 鼠标从某元素移开。
onmouseover 鼠标移到某元素之上。 onselect 在文本框中的文本被选中时发生。
onsubmit 确认按钮被点击,使用的对象是form。
事件要想被触发就要事先将其绑定到对应的标签上,JavaScript绑定事件的方式有:
1,在标签内添加事件属性
<div id="d1" onclick="changeColor(this);">点我</div> // this表示触发事件的当前元素
<script>
function changeColor(ths) {
ths.style.backgroundColor="green";
}
</script>
2,在body标签的最后的script标签里添加事件
<div id="d2">点我</div>
<script>
var divEle2 = document.getElementById("d2");
divEle2.onclick=function () {
this.innerText="真点啊";
}
</script>
转载自蔠缬草
前端开发之BOM和DOM(转载)的更多相关文章
- 前端开发之BOM和DOM
BOM BOM:是指浏览器对象模型,它使JavaScript可以和浏览器进行交互. 1,navigator对象:浏览器对象,通过这个对象可以判定用户所使用的浏览器,包含了浏览器相关信息. naviga ...
- 前端开发之JavaScript HTML DOM理论篇二
主要内容: 1.HTML DOM元素 2.HTML DOM事件 一.DOM元素 主要操作有添加.删除和替换HTML元素 1.创建新的HTML元素 (1)方法一: appendChild() 追加 如 ...
- 前端开发之JavaScript HTML DOM理论篇一
主要内容: 1.DOM简介 2.DOM 节点 3.DOM 方法和属性 4.DOM 访问和修改 一.DOM简介 1.什么是 DOM? DOM 是 W3C(万维网联盟)的标准. DOM 定义了访问 HTM ...
- 前端开发之JavaScript HTML DOM实战篇
实战案例一: “灯泡发光” <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- JS BOM DOM对象 select联动 计时器 时间 css操作 节点(标签 ) 查找标签 {前端基础之BOM和DOM}
前端基础之BOM和DOM 前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互,我 ...
- 前端基础之BOM和DOM day52
前端基础之BOM和DOM 前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互 ...
- day 47 前端基础之BOM和DOM
前端基础之BOM和DOM 前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些 ...
- 前端知识之BOM和DOM
前端基础之BOM和DOM windw对象 指浏览器窗口,所有的浏览器都支持window对象 常用的window方法 window.innerHeight 浏览器窗口的内部高度 window.inner ...
- #笔记# 移动前端开发之viewport
一般移动设备的浏览器都默认设置了一个 viewport ,并初始定义一个虚拟的layout viewport(布局视口),用于解决早期的页面在手机上显示的问题.下面我们来认识几个与 viewport ...
随机推荐
- Leetcode581.Shortest Unsorted Continuous Subarray最短无序连续子数组
给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. 你找到的子数组应是最短的,请输出它的长度. 示例 1: 输入: [2, 6, 4, 8, 1 ...
- Leetcode665.Non-decreasing Array非递减数组
给定一个长度为 n 的整数数组,你的任务是判断在最多改变 1 个元素的情况下,该数组能否变成一个非递减数列. 我们是这样定义一个非递减数列的: 对于数组中所有的 i (1 <= i < n ...
- 陈云川的OPENLDAP系列
前言 本 来,我应该准备一篇精彩的演说辞,从LDAP应用的方方面面讲起,细数LDAP在各种场合应用的成功案例,大肆渲染LDAP应用的辉煌前景,指出有多少机 构和组织的关键业务是建立在LDAP的基础上的 ...
- js里面的this指向
1. this是动态绑定的,或者说是在代码运行期绑定而不是在书写期 function fire () { console.log(this.a) } var obj = { a: 1, fire: ...
- Thread.sleep
Thread.sleep() The current thread changes state from Running to Waiting/Blocked as shown in the diag ...
- Direct2D 第3篇 绘制文字
原文:Direct2D 第3篇 绘制文字 #include <windows.h> #include <d2d1.h> #include <d2d1helper.h> ...
- 地不安装Oracle,plsql远程连接数据库
由于Oracle的庞大,有时候我们需要在只安装Oracle客户端如plsql.toad等的情况下去连接远程数据库,可是没有安装Oracle就没有一切的配置文件去支持.最后终于发现一个很有效的方法,Or ...
- PHP实现选择排序的方法
选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理如下.首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然 ...
- Qt添加右键菜单
QAction *hideAction = new QAction(tr(" 隐藏"),this); addAction(hideAction); setContextMenuPo ...
- CSS基础学习中的几大要点心得
CSS是前端学习中较为简单但又非常复杂的课程,说简单是因为学习它并不需要太多推理论证和逻辑思维,说它非常复杂则是更多的侧重在它的“杂”上,因为太多的格式和套路需要我们注意.以下谨列出本人在CSS学习中 ...