update: refactor
This commit is contained in:
206
06-前端基本功:CSS和DOM练习/05-DOM操作练习:访问关系的封装.md
Normal file
206
06-前端基本功:CSS和DOM练习/05-DOM操作练习:访问关系的封装.md
Normal file
@@ -0,0 +1,206 @@
|
||||
|
||||
|
||||
|
||||
## 访问关系的函数封装
|
||||
|
||||
(1)函数封装
|
||||
|
||||
新建一个文件名叫`tools.js`,然后在里面封装访问关系。代码如下。
|
||||
|
||||
|
||||
|
||||
tools.js:
|
||||
|
||||
```javascript
|
||||
/**
|
||||
* Created by smyhvae on 2018/01/28.
|
||||
*/
|
||||
|
||||
function getEle(id){
|
||||
return document.getElementById(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 功能:给定元素查找他的第一个元素子节点,并返回
|
||||
* @param ele
|
||||
* @returns {Element|*|Node}
|
||||
*/
|
||||
function getFirstNode(ele){
|
||||
var node = ele.firstElementChild || ele.firstChild;
|
||||
return node;
|
||||
}
|
||||
|
||||
/**
|
||||
* 功能:给定元素查找他的最后一个元素子节点,并返回
|
||||
* @param ele
|
||||
* @returns {Element|*|Node}
|
||||
*/
|
||||
function getLastNode(ele){
|
||||
return ele.lastElementChild || ele.lastChild;
|
||||
}
|
||||
|
||||
/**
|
||||
* 功能:给定元素查找他的下一个元素兄弟节点,并返回
|
||||
* @param ele
|
||||
* @returns {Element|*|Node}
|
||||
*/
|
||||
function getNextNode(ele){
|
||||
return ele.nextElementSibling || ele.nextSibling;
|
||||
}
|
||||
|
||||
/**
|
||||
* 功能:给定元素查找他的上一个兄弟元素节点,并返回
|
||||
* @param ele
|
||||
* @returns {Element|*|Node}
|
||||
*/
|
||||
function getPrevNode(ele){
|
||||
return ele.previousElementSibling || ele.previousSibling;
|
||||
}
|
||||
|
||||
/**
|
||||
* 功能:给定元素和索引值查找指定索引值的兄弟元素节点,并返回
|
||||
* @param ele 元素节点
|
||||
* @param index 索引值
|
||||
* @returns {*|HTMLElement}
|
||||
*/
|
||||
function getEleOfIndex(ele,index){
|
||||
return ele.parentNode.children[index];
|
||||
}
|
||||
|
||||
/**
|
||||
* 功能:给定元素查找他的所有兄弟元素,并返回数组
|
||||
* @param ele
|
||||
* @returns {Array}
|
||||
*/
|
||||
function getAllSiblings(ele){
|
||||
//定义一个新数组,装所有的兄弟元素,将来返回
|
||||
var newArr = [];
|
||||
var arr = ele.parentNode.children;
|
||||
for(var i=0;i<arr.length;i++){
|
||||
//判断:对同级的所有元素节点进行遍历,如果不是传递过来的元素自身,那就是兄弟元素,于是添加到新数组中。
|
||||
if(arr[i]!==ele){
|
||||
newArr.push(arr[i]);
|
||||
}
|
||||
}
|
||||
return newArr;
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
|
||||
上方代码中,我们单独来重视一下最后一个方法:获取指定元素的兄弟元素:
|
||||
|
||||
|
||||
```javascript
|
||||
/**
|
||||
* 功能:给定元素查找他的所有兄弟元素,并返回数组
|
||||
* @param ele
|
||||
* @returns {Array}
|
||||
*/
|
||||
function getAllSiblings(ele){
|
||||
//定义一个新数组,装所有的兄弟元素,将来返回
|
||||
var newArr = [];
|
||||
var arr = ele.parentNode.children;
|
||||
for(var i=0;i<arr.length;i++){
|
||||
//判断:对同级的所有元素节点进行遍历,如果不是传递过来的元素自身,那就是兄弟元素,于是添加到新数组中。
|
||||
if(arr[i]!==ele){
|
||||
newArr.push(arr[i]);
|
||||
}
|
||||
}
|
||||
return newArr;
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
(2)函数的调用举例:
|
||||
|
||||
```html
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head lang="en">
|
||||
<meta charset="UTF-8">
|
||||
<title></title>
|
||||
<style>
|
||||
li {
|
||||
width: 100px;
|
||||
height: 100px;
|
||||
background-color: pink;
|
||||
margin: 5px;
|
||||
list-style: none;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<ul>
|
||||
<li></li>
|
||||
<li></li>
|
||||
<li id="box"></li>
|
||||
<li></li>
|
||||
<li></li>
|
||||
</ul>
|
||||
<script src="tools.js"></script>
|
||||
<script>
|
||||
|
||||
//获取box改为red
|
||||
var box = getEle("box");
|
||||
box.style.backgroundColor = "red"
|
||||
|
||||
//获取第一个和最后一个子节点
|
||||
var parent = box.parentNode;
|
||||
getFirstNode(parent).style.backgroundColor = "yellow";
|
||||
getLastNode(parent).style.backgroundColor = "yellow";
|
||||
|
||||
//获取上一个和下一个兄弟节点
|
||||
getNextNode(box).style.backgroundColor = "blue";
|
||||
getPrevNode(box).style.backgroundColor = "blue";
|
||||
|
||||
|
||||
//指定兄弟节点
|
||||
getEleOfIndex(box,0).style.backgroundColor = "green";
|
||||
getEleOfIndex(box,1).style.backgroundColor = "green";
|
||||
|
||||
//获取所有的兄弟节点(返回值是数组,所以用for循环操作)
|
||||
var arr = getAllSiblings(box);
|
||||
for(var i=0;i<arr.length;i++){
|
||||
arr[i].style.backgroundColor = "green";
|
||||
}
|
||||
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
|
||||
```
|
||||
|
||||
注意:上方代码中,我们引用到了`tools.js`这个工具类。
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
```
|
||||
|
||||
|
||||
```
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
```
|
||||
|
||||
|
||||
```
|
||||
|
||||
|
||||
|
||||
|
||||
```
|
||||
|
||||
|
||||
```
|
||||
|
||||
|
||||
Reference in New Issue
Block a user