DOM 操作
DOM节点
childNodes nodeType 节点类型 -->3文本节点 -->1元素节点
获取子节点
children 子节点
parentNode 父节点
例子:点击链接,隐藏整个li
offsetParent 获取元素在页面上相对谁定位
首尾子节点
有兼容性问题 --> nodeType
firstChild、firstElementChild
lastChild 、lastElementChild
兄弟节点
有兼容性问题
nextSibling、nextElementSibling
previousSibling、previousElementSibling
操纵元素属性
元素属性操作
第一种:oDiv.style.display=“block”;
第二种:oDiv.style[“display”]=“block”;
第三种:Dom方式
DOM方式操作元素属性
获取:getAttribute(名称)
设置:setAttribute(名称, 值)
删除:removeAttribute(名称)
DOM元素灵活查找
用className选择元素
如何用className选择元素
选出所有元素
通过className条件筛选
封装成函数
创建、插入和删除元素
创建DOM元素
createElement(标签名) 创建一个节点 document.createElement('li');
appendChild(节点) 追加一个节点 父级.apppendChild(子节点)
例子:为ul插入li
插入元素
insertBefore(节点, 原有节点) 在已有元素前插入 oUl.insertBefore(oLi, aLi[0]);
例子:倒序插入li
删除DOM元素
removeChild(节点) 删除一个节点 oUl.removeChild(this.parentNode);
例子:删除li
文档碎片
文档碎片可以提高DOM操作性能(理论上)
文档碎片原理
document.createDocumentFragment() //但是现在几乎不用这个 低级浏览器 几乎无用
表格应用
tBodies、tHead、tFoot、rows、cells
// alert(aTb.getElementsByTagName('tbody')[0].getElementsByTagName('tr')[0].getElementsByTagName('td')[1].innerHTML);
alert(aTb.tBodies[0].rows[0].cells[1].innerHTML);
隔行变色
鼠标移入高亮
添加、删除一行
DOM方法的使用
搜索 ----> 主要是后端
版本1:基础版本——字符串比较
版本2:忽略大小写——大小写转换
版本3:模糊搜索——search的使用
版本4:多关键词——split
高亮显示、筛选 background / display
window.onload =function(){
var oTb = document.getElementById('table1');
var oT1 = document.getElementById('text1');
var oBtn1 = document.getElementById('btn1');
oBtn1.onclick = function (){
for(var i = 0; i < oTb.tBodies[0].rows.length; i++){
var search = oT1.value.toLowerCase();
var oldText = oTb.tBodies[0].rows[i].cells[1].innerHTML.toLowerCase();
var arr = search.split(' ');
oTb.tBodies[0].rows[i].style.background = '';
for(var j = 0; j < arr.length; j++){
if( oldText.search(arr[j]) != -1){
oTb.tBodies[0].rows[i].style.background = 'green';
}
}
}
}
}
排序
移动Li appendChild(); //1.从原有父级删掉2.添加到新的父级
元素排序:转换——排序——插入
window.onload =function(){
var oTb = document.getElementById('table1');
var oBtn1 = document.getElementById('btn1');
oBtn1.onclick = function (){
var arr = [];
for(var i = 0; i < oTb.tBodies[0].rows.length; i++){
arr[i] = oTb.tBodies[0].rows[i];
}
arr.sort(function (num1, num2){
var n1 = parseInt(num1.cells[0].innerHTML);
var n2 = parseInt(num2.cells[0].innerHTML);
return (n1 - n2);
});
for (var i in arr){
oTb.tBodies[0].appendChild(arr[i]);
}
}
}
表单应用
表单基础知识
什么是表单
向服务器提交数据,比如:用户注册
action 提交到哪里
表单事件
onsubmit 提交时发生
onreset 重置时发生
表单内容验证
阻止用户输入非法字符 阻止事件
输入时、失去焦点时验证 onkeyup、onblur
提交时检查 onsubmit
后台数据检查