Dom Api之操作标签属性
标签元素的属性有两类:1.标签自带属性.2.自定义属性.
一、获取属性.
获取属性有两种方法:1.element.属性名.2.element.getAttribute(属性名).下面用代码看一下他们的区别:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
<title>dom api</title>
</head>
<body>
<header>dom api</header>
<button>button</button>
<div id='count' name='div'>0</div>
</body>
<script>
//获取button标签
let buttonEle = document.querySelector('button');
//获取div标签
let divEle = document.querySelector('#count');
//为button的onclick绑定事件
buttonEle.onclick = function() {
console.log('divEle.id: ' + divEle.id);
console.log('divEle.name: ' + divEle.name);
console.log('getAttribute-id: ' + divEle.getAttribute('id'));
console.log('getAttribute-name: ' + divEle.getAttribute('name'));
}
</script>
</html>
可以看到,通过element.属性值来获取的只能是标签的自带系统属性,我们自定义的属性通过这种方式是获取不到的;而element.getAttribute(属性名)则可以获取以上两种属性.
二、设置属性.
设置属性也有两种方式,与获取类似:1.element.属性名.2.element.getAttribute(属性名).通过代码看一下他们的区别:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
<title>dom api</title>
</head>
<body>
<header>dom api</header>
<button>button</button>
<div id='count'>0</div>
</body>
<script>
//获取button标签
let buttonEle = document.querySelector('button');
//获取div标签
let divEle = document.querySelector('#count');
//为button的onclick绑定事件
buttonEle.onclick = function() {
divEle.name = '233';
divEle.id = 'countEle';
console.log('divEle.name: ' + divEle.getAttribute('name'));
console.log('divEle.id: ' + divEle.id);
divEle.setAttribute('name', '233');
divEle.setAttribute('id', 'countNewId');
console.log('divEle.setAttribute-name: ' + divEle.getAttribute('name'));
console.log('divEle.setAttribute-id: ' + divEle.id);
divEle.removeAttribute('id');
divEle.removeAttribute('name');
}
</script>
</html>
当点击按钮后:
阔以看到,当我们通过element.属性名设置属性时,只对自带属性有效.而element.setAttribute可以设置任何类型的属性.removeAttribute会移除任何类型的属性.
三、dataset.
dataset是h5新增的属性,它提倡我们以data-属性名的格式命名自定义属性,这么做,1是方便区分自定义属性和自带属性.2是在js中可以使用dataset来获取和设置自定义属性.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
<title>dom api</title>
</head>
<body>
<header>dom api</header>
<button>button</button>
<div id='count'>0</div>
</body>
<script>
//获取button标签
let buttonEle = document.querySelector('button');
//获取div标签
let divEle = document.querySelector('#count');
//为button的onclick绑定事件
buttonEle.onclick = function() {
divEle.dataset['name'] = 'countDiv';
console.log(divEle);
}
</script>
</html>
可以看到,当我们使用dataset来设置自定义属性时,它会自动在属性名前添加'data-'前缀.
同理,我们获取的时候,也只是通过data-后面的名字来操作的:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
<title>dom api</title>
</head>
<body>
<header>dom api</header>
<button>button</button>
<div id='count'>0</div>
</body>
<script>
//获取button标签
let buttonEle = document.querySelector('button');
//获取div标签
let divEle = document.querySelector('#count');
//为button的onclick绑定事件
buttonEle.onclick = function() {
divEle.dataset['countName'] = 'countDiv';
console.log(divEle);
console.log("divEle.dataset['countName']: " + divEle.dataset['countName']);
console.log("divEle.dataset.countName: " + divEle.dataset.countName);
}
</script>
</html>
需要注意的是,当自定义属性的名字段数比较多时,如上面的data-count-name,我们需要通过驼峰命名发来获取和设置dataset中的属性值.