节点操作
1、父节点
node.parentNode
parentNode属性可返回某节点最近的一个的父节点
如果指定的节点没有父节点则返回null
2、子节点
1.子节点childNode 所有的子节点,包含元素节点 文本节点等等
2.children 获取所有的子元素节点(常用)
3、获取第一个元素和最后一个元素
1.firstChild第一个子节点 不管是文本节点还是元素节点
ol.firstChild
ol.lastChild
2.firstElementChild 返回第一个子元素节点
ol.firstElementChild
ol.lastElementChild
3.实际开发的写法 既没有兼容性问题又返回第一个子元素
ol.children[0]
ol.children[ol.children.length -1]
4、兄弟节点
1.nextSibling(previousSibling) 上下兄弟节点,包含元素节点或者文本节点
2.nextElementSibling(previousElementSibling) 得到上下兄弟元素节点(有兼容性问题)
5、创建和添加元素节点
<ul>
<li>1</li>
</ul>
6、下拉菜单
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
* {
margin: 0;
padding: 0;
}
li {
list-style-type: none;
}
a {
text-decoration: none;
font-size: 14px;
}
.nav {
margin: 100px;
}
.nav>li {
position: relative;
float: left;
width: 80px;
height: 41px;
text-align: center;
}
.nav li a {
display: block;
width: 100%;
height: 100%;
line-height: 41px;
color: #333;
}
.nav>li>a:hover {
background-color: #eee;
}
.nav ul {
display: none;
position: absolute;
top: 41px;
left: 0;
width: 100%;
border-left: 1px solid #FECC5B;
border-right: 1px solid #FECC5B;
}
.nav ul li {
border-bottom: 1px solid #FECC5B;
}
.nav ul li a:hover {
background-color: #FFF5DA;
}
</style>
</head>
<body>
<ul class="nav">
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>