01.自定义属性

1.自定义属性:

作用:保存数据 通用的自定义属性的前缀 data-属性="属性值"

注:自定义的属性不能通过 元素.属性 取属性值 ,需使用getAttribute();

2.自定义属性的获取

元素.getAttribute('data-url');

3.设置

节点.setAttribute('属性名称','修改后的属性值'); (修改后的属性值是一个变量的时候,不加引号)

4.删除

元素.removeAttribute('data-url');

  1. 简单测试:
    <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');

02.自定义属性案例

鼠标滑过,切换图片

  1. <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>

03.innerHTML,outerHTML

  1. <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>

04.自定义属性案例(换肤)

  1. css/style1.css,css/style2.css/...css/style5.css:
    body{
       background:url(../images/rose1.jpg) no-repeat;
       background-size:100% 100%;
    }//同理,将5个图片作为背景图切换
    <link rel="stylesheet" href="./css/style1.css">
    <style>
       *{
       margin:0;
       padding:0;
    }
    html,body{
           width:100%;
           height:100%;
      }
    </style>
    <script>
       <button>换肤</button>
    <script src="../myApi.js"></script>
    <script>
           //获取元素button
           var oBtn = document.querySelector('button');
    //获取换肤的每一个样式
    var oLink = document.querySelector('link');
    //给按钮绑定单击事件
    oBtn.onclick = function(){
               //随机换肤
               var num = randomNum(1,5);
               //使用字符串拼接,拼成修改的样式的路径
               var url = './css/style'+ num + '.css';
               //setAttribute设置切换的link的href,通过更改href,来完成换肤的效果
               oLink.setAttribute('href',url);
          }
       </script>
    </script>

05.dom节点的获取

  1. <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>
  2.  
  3. 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>

06.商品的加减

  1. <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>

07.className,tagName

1.获取行间样式

节点.className 获取/设置 类名

节点.tagName 获取标签名 都是大写的

2.js动态获取更改 某个元素的html属性

元素.属性 设置/获取

自定义属性: getAttribute(获取) setAttribute(设置)

  1. <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>

08.更改或者是获取css属性(获取非行间样式)

1.设置css样式

节点.style.css属性 = ’属性值‘

节点.style.cssText = 'width:300px;height:300px;background:red;'

2.获取非行间样式

getComputedStyle(元素,null)[attr] 存在兼容(window下的方法)

元素.currentStryle[attr] IE

封装获取非行间样式的方法:

  1. 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

09.js改变轮播图圆点样式

  1. <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>

10.点击元素获取当前元素的下标

  1. <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属性的更多相关文章

  1. JavaScript DOM节点操作总结

    节点类型 节点类型主要有三种:元素节点,属性节点和文本节点. 而对DOM的主要也就是围绕元素节点和属性节点的增删改查.下面就分别从对元素节点的操作和对属性节点的操作来介绍. 元素节点 查 在对DOM进 ...

  2. js原生获取元素的css属性

    习惯了用jQuery的css()的方法获取元素的css属性,突然不用jquery了,当要获得元素的css时候,我瞬间停顿了一下,咦?咋获取元素的css值?比如获取元素的width.是这样么?docum ...

  3. js原生获取css属性

    原文参考http://blog.csdn.net/lzding/article/details/46317777 1.写在dom上的属性,内联样式 <div id="box" ...

  4. JavaScript获取HTML DOM节点元素详解(转)

    在Web运用程序特别是Web 2.0程序开发中,经常要获取页面中某个元素,然后更新该元素的样式.内容等.如何获取要更新的元素,是首先要处理的疑问. 51CTO推荐阅读:JavaScript DOM文档 ...

  5. jacascript DOM节点——节点获取与选择器API

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! DOM 操作必须等待 HTML 加载完毕之后,才可以获取节点:有两种方法: 把 script 标签放到代码 ...

  6. DOM节点中获取文本易混淆的属性

    DOM 节点中对于获取文本易混淆的属性,innerText, innerHTML, outerHTML, textContent, nodeValue. 一个实例: <!DOCTYPE html ...

  7. 通过DOM节点操作来获取表单信息

    这是之前突发奇想地用dom节点的关系来操作表单的故事.. 事情的经过是这样的,大概就是一个平台注册后有留言功能,管理员登录之后可以对这些留言进行回复.这个页面呢,就是通过foreach获取到数据库里的 ...

  8. 六、React 键盘事件 表单事件 事件对象以及React中的ref获取dom节点 、React实现类似Vue的双向数据绑定

    接:https://www.cnblogs.com/chenxi188/p/11782349.html 事件对象 .键盘事件. 表单事件 .ref获取dom节点.React实现类似vue双向数据绑定 ...

  9. (转载)html dom节点操作(获取/修改/添加或删除)

    DOM 是关于如何获取.修改.添加或删除 HTML 元素的标准,下面为大家介绍下html dom节点操作,感兴趣的朋友可以参考下   HTML DOM 是关于如何获取.修改.添加或删除 HTML 元素 ...

随机推荐

  1. Spring MVC浅入浅出——不吹牛逼不装逼

    Spring MVC浅入浅出——不吹牛逼不装逼 前言 上文书说了Spring相关的知识,对Spring来了个浅入浅出,大家应该了解到,Spring在三层架构中主做Service层,那还有Web层,也就 ...

  2. ubuntu安装伪分布式Hadoop3.1.2

    作业要求:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE1/homework/3223 本文是基于已经安装好的ubuntu环境上搭建伪分布式hadoop,在 ...

  3. java并发编程(五)----(JUC)ReentrantLock

    上一节我们了解了Lock接口的一些简单的说明,知道Lock锁的常用形式,那么这节我们正式开始进入JUC锁(java.util.concurrent包下的锁,简称JUC锁).下面我们来看一下Lock最常 ...

  4. 【POJ - 2229】Sumsets(完全背包)

    Sumsets 直接翻译了 Descriptions Farmer John 让奶牛们找一些数加起来等于一个给出的数N.但是奶牛们只会用2的整数幂.下面是凑出7的方式 1) 1+1+1+1+1+1+1 ...

  5. if IE语句 | 判断浏览器IE版本及添加升级提示

    本文引自:http://blog.csdn.net/u013372487/article/details/48521929 实现方法 判断当前浏览器是否IE6(或IE6内核) <!--[if I ...

  6. org.apache.spark.logging类报错

    一,1 在使用spark读取kafka数据时,当spark升级到2.0之后,出现如上问题:之前遇到了,当时在工程里面添加了org.apache.spark.Logging类,能够运行. 但是在后期使用 ...

  7. C语言编程入门之--第五章C语言基本运算和表达式-part2

    5.1.4 再来一个C库函数getchar吸收回车键 回车键也是一个字符,在使用scanf的时候,输入完毕要按下回车键,这时候回车键也会被输入到stdin流中,会搞乱我们的程序. 注意:stdin是输 ...

  8. JS判断字符串长度,结合element el-input el-form 表单验证(英文占1个字符,中文汉字占2个字符)

    首先看看判断字符串长度的几种方法(英文占1个字符,中文汉字占2个字符) 方法一: function strlen(str) { var len = 0; for (var i = 0; i < ...

  9. let 、const 、var、function声明关键字的新理解

    今天在群里看到大佬们讨论let .const 的提升问题,有个大佬问  三种声明都在什么阶段提升?  什么阶段?这个真不清楚,以前是只知道let.const存在死区,没有变量提升,一下子就懵了 后经手 ...

  10. ASP.NET Core on K8S深入学习(5)Rolling Update

    本篇已加入<.NET Core on K8S学习实践系列文章索引>,可以点击查看更多容器化技术相关系列文章. 一.什么是Rolling Update? 为了服务升级过程中提供可持续的不中断 ...