H5自定义属性
自定义属性目的
- 目的:是为了保存并且使用数据。有些数据可以把保存到页面中而不用保存到数据库。可以通过getAttribute获取。
- 自定义属性:
data-
开头。这是一种规范。 - dataset:存储着以data开头的自定义属性。
- 获取自定义属性:如data-index的dataset[‘index’]、dataset.index。
- 如果有多个短横线:以驼峰命名法获取。如
data-set-name
和dataset[listname]
节点操作
为什么节点操作
- 获取元素俩种方式:利用DOM提供的方法获取元素。缺点代码繁琐,逻辑性不强。所以用节点操作。
- 节点操作:利用父子关系获取元素。
什么是节点
- 节点:DOM树里都是节点,页面所有内容都是节点。如元素节点、文档节点、文本节点。
- 元素节点nodeType为1、属性节点nodeType为2、文本节点nodeType为3(包含空格、文字、换行)。
节点层级
- 父节点:parentNode获取离他最近的父节点。
- 子节点:childNode。包括元素节点(li)和换行(text)文本节点。所以用parentNode.children
- 兄弟节点:下一个兄弟元素节点
div.nextElementSibling
。下一个兄弟节点包括空格换行,nextSibling
- 第一个和最后一个子节点:parentNode.firstChild和parentNode.lastChild
- 第一个元素节点。比如
<li>woshishui</li>
。firstElementChild拿到<li>woshishui</li>
。IE9以上支持。所以用children[0]。最后一个children[children.length-1]
- 创建节点:
var li = doucument.createElement('li')
,需要用到添加节点 - 添加节点:
ul.appendChild(li)
。如果有li了,那就添加到后面。想插在前面用ul.insertBefore(li,ul.children[0])。
- 删除节点:
ul.removeChild(ul.children[0])
。thia.diabled = true(禁用节点,没了就不能删除了) javascript:;
无跳转- 复制节点:
ul.appendChild(ul.children[0].cloneNode())
。只复制标签不复制内容,浅拷贝。想复制内容必须在括号里加true。cloneNode(true)
三种动态创建元素区别
- document.write() 创建元素 如果页面文档流加载完毕,再调用这句话会导致页面重绘
- innerTHML和createElement效率对比:innerHTML字符串拼接方式(效率低)、createElement方式(效率一般但是结构清晰)、innerHTML数组方式(效率高)。
<script>
var btn = document.querySelector('button');
btn.onclick = function() {
document.write('<div>123</div>');
}
var inner = document.querySelector('.inner');
for (var i = 0; i <= 100; i++) {
inner.innerHTML += '<a href="#">百度</a>'
}
var arr = [];
for (var i = 0; i <= 100; i++) {
arr.push('<a href="#">百度</a>');
}
inner.innerHTML = arr.join('');
var create = document.querySelector('.create');
for (var i = 0; i <= 100; i++) {
var a = document.createElement('a');
create.appendChild(a);
}
</script>
DOM核心
- 文档对象类型(简称DOM)是W3C推荐的处理可扩展标记语言标准接口
- 可以通过DOM改变网页内容、结构和样式。返回的是对象。
增删改查
doucument.write();
innerHTML;
creteElement;
appendchild();
insertBefore();
removeChild();
src、href、title
innerHTML、innerText
value、type、disabled
style、className
getElementById();
quertSelector
setAttribute
getArrtibute
例题
导航栏。鼠标经过离开
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<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 {
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;
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>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
<li>
<a href="#">微博</a>
<ul>
<li>
<a href="">私信</a>
</li>
<li>
<a href="">评论</a>
</li>
<li>
<a href="">@我</a>
</li>
</ul>
</li>
</ul>
<script>
var nav = document.querySelector('.nav');
var lis = nav.children;
for (var i = 0; i < lis.length; i++) {
lis[i].onmouseover = function() {
this.children[1].style.display = 'block';
}
lis[i].onmouseout = function() {
this.children[1].style.display = 'none';
}
}
</script>
</body>
</html>
发布留言
- 删除节点;
ul.removeChild(this.parentNode);
<!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;
}
textarea {
width: 200px;
height: 100px;
border: 1px solid pink;
outline: none;
resize: none;
}
ul {
margin-top: 50px;
}
li {
width: 300px;
padding: 5px;
background-color: rgb(245, 209, 243);
color: red;
font-size: 14px;
margin: 15px 0;
}
li a {
float: right;
}
</style>
</head>
<body>
<textarea name="" id=""></textarea>
<button>发布</button>
<ul>
</ul>
<script>
var btn = document.querySelector('button');
var text = document.querySelector('textarea');
var ul = document.querySelector('ul');
btn.onclick = function() {
if (text.value == '') {
alert('您没有输入内容');
return false;
} else {
var li = document.createElement('li');
li.innerHTML = text.value + "<a href='javascript:;'>删除</a>";
ul.insertBefore(li, ul.children[0]);
var as = document.querySelectorAll('a');
for(var i = 0;i<as.length ; i++){
as[i].onclick = function(){
ul.removeChild(this.parentNode);
}
}
}
}
</script>
</body>
</html>
动态创建和删除元素
<!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>
table {
width: 500px;
margin: 100px auto;
border-collapse: collapse;
text-align: center;
}
td,
th {
border: 1px solid #333;
}
thead tr {
height: 40px;
background-color: #ccc;
}
</style>
</head>
<body>
<table cellspacing="0">
<thead>
<tr>
<th>姓名</th>
<th>科目</th>
<th>成绩</th>
<th>操作</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
<script>
var datas = [{
name: '魏璎珞',
subject: 'JavaScript',
score: 100
}, {
name: '弘历',
subject: 'JavaScript',
score: 98
}, {
name: '傅恒',
subject: 'JavaScript',
score: 99
}, {
name: '明玉',
subject: 'JavaScript',
score: 88
}, {
name: '大猪蹄子',
subject: 'JavaScript',
score: 0
}];
var tbody = document.querySelector('tbody');
for (var i = 0; i < datas.length; i++) {
var tr = document.createElement('tr');
tbody.appendChild(tr);
for (var k in datas[i]) {
var td = document.createElement('td');
td.innerHTML = datas[i][k];
tr.appendChild(td);
}
var td = document.createElement('td');
td.innerHTML = '<a href="javascript:;">删除 </a>';
tr.appendChild(td);
}
var as = document.querySelectorAll('a');
for (var i = 0; i < as.length; i++) {
as[i].onclick = function() {
tbody.removeChild(this.parentNode.parentNode)
}
}
</script>
</body>
</html>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)