作用:保存数据 通用的自定义属性的前缀 data-属性="属性值"
注:自定义的属性不能通过 元素.属性 取属性值 ,需使用getAttribute();
元素.getAttribute(‘data-url‘);
节点.setAttribute(‘属性名称‘,‘修改后的属性值‘); (修改后的属性值是一个变量的时候,不加引号)
元素.removeAttribute(‘data-url‘);
简单测试:
<img src="./images/1.jpg" alt="" data-url="./images/a.jpg">
//获取自定义属性:
var oImg = document.querySelector(‘img‘);
console.log(oImg.getAttribute(‘data-url‘));
//设置自定义属性
var oImg = document.querySelector(‘img‘);
oImg.setAttribute(‘data‘,‘ddddd‘);
//删除
var oImg = document.querySelector(‘img‘);
oImg.removeAttribute(‘data-url‘);
鼠标滑过,切换图片
<style>
    *{
        margin:0;
        paddin:0;
    }
    .showImg{
        width:300px;
        height:300px;
        border:1px solid red;
    }
    .showImg img{
        display:block;
        width:100%;
        height:100%;
    }
    .btnImg{
        width:300px;
        height:60px;
        border:1px solid red;
    }
    .btnImg img{
        width:60px;
        height:60px;
        display:block;
        float:left;
        cursor:pointer;
    }
</style>
<section class="showImg">
    <img src="./images/rose1.jpg" alt="">
</section>
<div class="btnImg">
    <img src="./images/rose1.jpg" alt="">
    <img src="./images/rose2.jpg" alt="">
    <img src="./images/rose3.jpg" alt="">
    <img src="./images/rose4.jpg" alt="">
    <img src="./images/rose5.jpg" alt="">
</div>
<script>
    //鼠标滑过事件  onmouseover
    //如果获取的是一个节点集合,并且给每一个元素绑定事件,需要遍历
    var aImg = document.querySelector(‘.showImg img‘);
    var bigImg = document.querySelectorAll(‘btnImg img‘);//获取到的是一个节点的集合
    for(var i = 0 ; i < bigImg.length ; i++){ //循环遍历,给每一个img绑定鼠标滑过事件
        //循环遍历,绑定事件(重点)
        bigImg[i].onmouseover = function(){
            //鼠标滑过每一个img的时候,获取它的src的值,直接更改大图的src
            aImg.src = this.src; //上面显示的图片的src就是在遍历时,获取的当前图片的src
            var src = this.getAttribute(‘src‘);  //获取当前图片的src
            aImg.setAttribute(‘src‘,src); //将设置显示区,显示当前图片的src
        }
    }
</script>
<section>
    section中的文本
    <div>
        div中的文本
    </div>
</section>
<script>
    var oS = document.querySelector(‘section‘);
    console.log(oS); //section里面的文本和div都获取到了
?
    var oS = document.querySelector(‘section‘);
    console.log(os.innerHTML);  //innerHTML除了可以设置,还可以获取,获取到的是section里面所有内容(包括标签)
    console.log(os.innerText);  //只获取section里面的所有文本
    console.log(os.outerHTML); //outerHTML ,获取到的是section和它里面的内容
    console.log(os.outerText); //和innerText一样,获取到所有文本内容
</script>
css/style1.css,css/style2.css/
<section>
    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>4</div>
    <div>5</div>
</section>
<img src="./images/rose1.jpg" alt="dkf" title="dfs">
<script>
    var os = document.querySelector(‘section‘);
    var adiv = os.querySelectorAll(‘div‘);
    console.log(os.firstChild); //获取第一个节点(元素节点,文本节点)
    console.log(os.lastChild); //获取最后一个界定啊(元素节点,文本节点)
    console.log(os.firstElementChild); //获取第一个元素节点(包括文本节点)。<div>1</div>
    console.log(os.lastElementChild); //获取最后一个元素(不包括文本节点)<div>4<div>
?
    console.log(adiv[1].previousSibling);//获取已知节点的相邻的上一个节点(可以获取到文本节点)
    console.log(adiv[1].previousElementSibling); //获取相邻的上一个元素节点<div></div>
    
    console.log(adiv[i].nextSibling); //获取已知节点的相邻的下一个节点(可以获取文本节点)
    console.log(adiv[i].nextElementSibling);//获取已知节点的下一个元素节点
?
    //替换节点 replaceChild(newNode,oldNode);
    var createP = document.createElement(‘p‘);
    createP.innerHTML = ‘新增加的‘;
    os.replaceChild(createP,adiv[3]); //把第4个div替换成p
?
    //ownerDocument 获取该节点的文档根节点 (相当于document)
    console.log(os.ownerDocument);  //获取section节点的文档根节点,结果为document
?
    //attributes 它是一个属性,获取当前元素节点的所有属性节点集合
    var oImg = document.querySelector(‘img‘);
    console.log(oImg.attributes); //获取到的是一个集合 NamedNodeMap {0: src, 1: alt, 2: title, src: src, alt: alt, title: title, length: 3}
    console.log(oImg.attributes[0]); //获取这个集合下的第一个属性  src="./images/rose1.jpg"
    console.log(oImg.attributes[0].nodeValue); //获取属性里面的值 ./images/rose1.jpg
    console.log(oImg.attributes[‘src‘]);//返回属性为src的节点
</script>
<style>
    #price,h3{
        font-size:30px;
        font-weight:900px;
        color:red;
    }
</style>
<h2>商品的单价:</h2>
<h3>1000</h3>
<div>
    <button class="minus">-</button>
    <input type="text" name="" id="" value="0">
    <button class="add">+</button>
</div>
<h2>总额:<span id="price">0</span></h2>
<script>
    var
        oMinus = document.querySelector(‘.minus‘),
        oAdd = document.querySelector(‘.add‘),
        oPrice = document.querySelector(‘#price‘);
        money = document.querySelector(‘h3‘).innerHTML; //获取h3的内容
    //加
    oAdd.onclick = function(){
        oAdd.previousElementSibling.value++;//点击+,改变上一个节点,input的值,每次点击+,值++
        oPrice.innerHTML = money * oAdd.previousElementSibling.value;
    }
    //减
    oMinus.onclick = function(){
        oMinus.nextElementSilbing.value--;//点击-,改变下一个节点,input的值,每次点击-,值--
        if(oMinus.nextElementSilbing.value <= 0){//当减到0时,再不允许--,将input的值保持为0
            oMinus.nextElementSibling.value = 0;    
        }
        oPrice.innerHTML = money * oMinus.nextElementSibling.value;
    }
</script>
节点.className 获取/设置 类名
节点.tagName 获取标签名 都是大写的
元素.属性 设置/获取
自定义属性: getAttribute(获取) setAttribute(设置)
<style>
    .box{
        width:300px;
        height:300px;
        background:red;
    }
    .wrap{
        border:10px solid orange;
    }
</style>
<div class = "box" title="ddd" style="border:30px solid blue;"></div>
<div title="ddd"></div>
<script>
    var oBox = document.querySelector(‘.box‘);
    console.log(oBox.className); //box
    console.log(oBox.tagName);  //DIV
?
    var oBox = document.querySelector(‘div‘);
    //没有类名的时候,动态添加类名
    oBox.className = ‘box‘;
    //要想把.wrap的样式添加给box
    //oBox.className = ‘wrap‘; //把样式重置了
    oBox.className = ‘ wrap‘; //要加上空格,不然就贴在一起了
?
    //根据类名,动态添加样式
    console.log(oBox.style);
</script>
节点.style.css属性 = ’属性值‘
节点.style.cssText = ‘width:300px;height:300px;background:red;‘
getComputedStyle(元素,null)[attr] 存在兼容(window下的方法)
元素.currentStryle[attr] IE
封装获取非行间样式的方法:
function getStyle(ele,attr){
    /*
        判断浏览器支持哪个方法
        //方法一:
        if(ele.currentStyle){
            return ele.currentStyle[attr];
        }else{
            return getComputedStyle(ele,null)[attr];
        }
        //方法二:
        return ele.currentStyle ? ele.currentStyle[attr] : getComputedStyle(ele,null)[attr];
    */
    return ele.currentStyle ? ele.currentStyle[attr] : getComputedStyle(ele,null)[attr];
}
console.log(getStyle(div,‘width‘)); //300px
console.log(getStyle(div,‘height‘));  //300px
<style>
    *{
        margin:0;
        padding:0;
    }
    section{
        width:500px;
        height:30px;
        margin:0 auto;
    }
    div{
        width:30px;
        height:30px;
        margin:0 10px;
        border-radius:50%;
        background:orange;
        float:left;
    }
    .active{
        background:blue;
    }
</style>
<section>
    <div class="active"></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
</section>
<script>
    //获取所有的div
    var aDiv = document.querySelectorAll(‘section div‘);
    //给每一个div绑定鼠标滑过的事件(循环遍历)
    for(var i = 0 ; i < aDiv.length ;i++){
        aDiv[i].onmouseover = function(){
            //每当鼠标滑过的时候,先把所有的div的active都取消
            for(var j = 0 ; j < aDiv.length ; j++){
                aDiv[j].className = ‘‘;
            }
            //鼠标滑过,改变它的样式,给它添加类名(使用className可以设置类名)
            this.className = ‘active‘;
        }
    }
</script>
<style>
    div{
        width:100px;
        height:100px;
        background:orange;
    }
</style>
<section>
    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>4</div>
    <div>5</div>
</section>
<script>
    var aDiv = document.querySelectorAll(‘section div‘);
    //绑定单击事件
    for(var i = 0 ; i < aDiv.length ; i++){
        /*
            aDiv[i].onclick = function(){
                console.log(i);  //5 泄露
            }
            循环:变量的泄露!!!  在循环里面,循环变量不会保存在循环的代码里面
        */
        //为每一个div添加一个属性,把i保存在属性里面
        aDiv[i].index = i;
        aDiv[i].onclick = function(){
            //打印下标
            console.log(this.index);
        }
    }
</script>自定义属性,innerHTML,outerHTML,dom节点的获取,className,tagName,更改或者是获取css属性
原文:https://www.cnblogs.com/ljp1997/p/11489042.html