Document Object Model,一种用于HTML和XML文档的编程接口。它给文档提供了一种结构化的表示方法,可以改变文档的内容和呈现方式,DOM把网页和脚本以及其他的编程语言联系了起来。DOM属于浏览器,而不是JavaScript语言规范里的规定的核心内容。
查找元素
直接查找
document.getElementById 根据ID获取一个标签document.getElementsByName 根据name属性获取标签集合document.getElementsByClassName 根据class属性获取标签集合document.getElementsByTagName 根据标签名获取标签集合
从上面可以看出,除了根据ID获取标签是一个数量外,其他的都是一个集合或者数组,可以是1个也可以是多个.
间接查找
parentNode // 父节点childNodes // 所有子节点firstChild // 第一个子节点lastChild // 最后一个子节点nextSibling // 下一个兄弟节点previousSibling // 上一个兄弟节点 parentElement // 父节点标签元素children // 所有子标签firstElementChild // 第一个子标签元素lastElementChild // 最后一个子标签元素nextElementtSibling // 下一个兄弟标签元素previousElementSibling // 上一个兄弟标签元素
例子:输入框默认文字
操作
内容操作
innerText 文本outerTextinnerHTML HTML内容innerHTML value 值
属性操作
attributes // 获取所有标签属性setAttribute(key,value) // 设置标签属性getAttribute(key) // 获取指定标签属性 /*var atr = document.createAttribute("class");atr.nodeValue="democlass";document.getElementById('n1').setAttributeNode(atr);*/
setAttributegetAttributeremoveAttribute===> tabObj.checked = true===>jQuery: 操作数据,prop(checked,true)
例子:列表全选取消反选
注意全选反选时,尽量使用obj.checked=true ,false,否则如果文件里还有setAttribute的话,会出现错误.
111 | 222 | |
111 | 222 | |
111 | 222 | |
111 | 222 |
class操作
className // 获取所有类名classList.remove(cls) // 删除指定类classList.add(cls) // 添加类
例子:遮罩隐藏登录
标签操作
创建标签
创建标签有两种方式:
- 对象方式
- 字符串方式
- 如果两种方式都出现的话,对象方式优先
// 方式一var tag = document.createElement('a')tag.innerText = "wupeiqi"tag.className = "c1"tag.href = "http://www.cnblogs.com/wupeiqi" // 方式二var tag = "wupeiqi"
//将标签添加到HTML中//字符串形式的标签: p1.insertAdjacentHTML('beforeEnd',tag);//对象形式的标签: p1.insertAdjacentElement('afterBegin',document.createElement('p')) xxx.insertBefore(tag,xxx[1])
例子:点赞漂+1
其中用到了定时器:setInterval
例子:模拟邮件删除提示
其中用到了单词定时器:setTimeout
操作标签
// 方式一var obj = "";xxx.insertAdjacentHTML("beforeEnd",obj);xxx.insertAdjacentElement('afterBegin',document.createElement('p')) //注意:第一个参数只能是'beforeBegin'、 'afterBegin'、 'beforeEnd'、 'afterEnd' // 方式二var tag = document.createElement('a')xxx.appendChild(tag)xxx.insertBefore(tag,xxx[1])
样式操作
var obj = document.getElementById('i1') obj.style.fontSize = "32px";obj.style.backgroundColor = "red";tag = .....tag.style.color = 'red';tag.style.fontSize = '40px';
例子:输入框关键字灰色
位置操作
总文档高度document.documentElement.offsetHeight 当前文档占屏幕高度document.documentElement.clientHeight 自身高度tag.offsetHeight 距离上级定位高度tag.offsetTop 父定位标签tag.offsetParent 滚动高度tag.scrollTop /* clientHeight -> 可见区域:height + padding clientTop -> border高度 offsetHeight -> 可见区域:height + padding + border offsetTop -> 上级定位标签的高度 scrollHeight -> 全文高:height + padding scrollTop -> 滚动高度 特别的: document.documentElement代指文档根节点*/
测试代码:
asdf
asdf
asdf
asdf
asdf
例子:滚动固定(这个比较屌)
例子:滚动高度
例子:返回顶层,并且最顶端不显示
返回顶部 返回顶部
提交表单
document.geElementById('form').submit()
其他操作
console.log 输出框alert 弹出框confirm 确认框 // URL和刷新location.href 获取URLlocation.href = "url" 重定向location.reload() 重新加载 // 定时器setInterval 多次定时器clearInterval 清除多次定时器setTimeout 单次定时器clearTimeout 清除单次定时器
例子:确认
var ret = confirm('是否删除?');console.log(ret);
事件
事件重要补充:
- this,当前触发事件的标签
- 全局事件绑定 window.onKeyDown = function(){}
- event,包含事件相关内容
- 默认事件:自定义优先:
a,form等
;默认优先:checkbox
事件优先例子:
百度
输入框例子: