<div id="box" class="box"></div>
 
-->  var myBox = document.getElementById("box");
 
-->  var myDivList = document.getElementsByTargetName(div);       // 注意    Eelements
 
-->  var myDivs = div.getElementsByClassName("box");                  //注意     Elements
 
 
-->  通过class选:支持IE9+
 
    兼容写法:

    function getElementsByClassName(node,className){
        if(node.getElementsByClassName){
            return node.getElementsByClassName(className)
        }else{
            var results = [];
            var items = node.getElementsByTagName("*");
            for (var i = 0; i < items.length; i++) {
                if(items[i].className == className){
                    results.push(items[i]);
                } 
            };
            return results;
        }
    }

-->   getAttribute();  setAttribute("id","app")

-->   nodeName   nodeValue     nodeType    
     
     元素节点   -->
     getAttributeNode() -->nodeType=2
     文本节点 --> 3
    
    

--> childNodes    firstChild    lastChild    parentNode  nextSiblling
 
--->window打开新窗口:   
 
  

 
 -->  addLoadEvent
 
  

 
 -->三元操作符   
  var a,b;
   if(a > 1){b=a+1}else{b=a-1}  ==>    a>1 ? b = a+1 : b = a - 1;
 
 
-->  document.write 和   innerHTML
 
 
-->  document.creatElement("p");        //创建 元素节点
   document.craeatTextNode();         //创建文本节点
--> parent.appendChild(child)
 
--> parentElement.insertBefore(newElement,targetElement);
--> 自己实现   insertAfter方法:

  function insertAfter(newEl,targetEl){
    var parentEl = targetEl.parentNode;
    if(parentEl.lastChild == targetEl){
      parentEl.appendChild(newEl);
    }else{
      parentEl.insertBefore(newEl,targetEl.nextSibling);
    }
  }

-->  nextSibling    与 自己创建的  getNextElement()函数:

  nextSibling  挨着的节点    利用 nodeType验证      1  对应 元素节点

                             2  对应 属性节点

                           3  对应文本节点

  

  下一个节点元素函数:

  function getNextElement(node){

      if(node.nodeType == 1){

        return node;

       }

      if(node.nextSibling){

        return getNextElement(node.nextSibling);     // 递归

      }

      return null;

  }

-->  addClass方法:

  

  function addClass(node,value){
    if(!node.className){
      node.className = value;
    }else{
      //直接用属性设置
      //node.setAttribute("class",node.className+" "+value)
      newClassName = node.className;
      //classname 之间的空格 不能缺失
      newClassName+=" ";
      newClassName+=value;
      node.className = newClassName;
    }
  }  

-->子元素节点:

  

  function childElement(el){
    var result=[];
    for (var i = 0; i < el.childNodes.length; i++) {
      if(el.childNodes[i].nodeType == 1){
      result.push(el.childNodes[i]);
      }
    };
    return result;

  }

  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
代码书写习惯,
a,  行末逗号
b,  空格缩进
c,  函数名称后无空格
d,  函数参数与括号间无空格
e,  对象字面量的冒号后加空格,冒号前不加
f,  条件语句关键字后加空格 
 
 
 
 
 
 注:截图源于 《 DOM编程艺术第二版》。只做分享,如有侵权,请联系本人,会马上删除!

从零开始 DOM操作 笔记的更多相关文章

  1. [笔记]原生JS实现的DOM操作笔记

    原生JS实现的DOM一系列操作参考: 原生JavaScript封装DOM库 siblings: 原生JS-查找相邻的元素-siblings方法的实现 addClass,removeClass,hasC ...

  2. [javascript]Dom操作笔记

    1.为一个节点同时设置多个属性 $("div[aria-describedby='F53_batch_history']").attr({"display":& ...

  3. jQuery学习笔记之DOM操作、事件绑定(2)

    jQuery学习笔记之DOM操作.事件绑定(2) --------------------学习目录------------------------ 4.DOM操作 5.事件绑定 源码地址: https ...

  4. HTML 学习笔记 JQuery(DOM 操作)

    一般来说,DOM操作分为三个方面,即:DOM Core(核心), HTML_DOM 和 CSS_DOM. 1.DOM Core DOM Core 并不专属于JavaScript,任何一种支持DOM的程 ...

  5. jQuery学习笔记(二)jQuery中DOM操作

    目录 DOM操作分类 jQuery中的各种DOM操作 查找节点 创建节点 删除节点 复制节点 替换节点 包裹节点 属性操作 样式操作 对HTML.文本和值的操作 遍历节点 CSS-DOM操作 小结 本 ...

  6. jquery学习笔记---Dom操作

    一.DOM操作的分类 DOM(document object model)是一种与浏览器.平台.语言无关的接口,使用该接口可以访问页面中的·所有组件.DOM的操作可以分为DOM Core.HTML-D ...

  7. jQuery选择器和DOM操作——《锋利的jQuery》(第2版)读书笔记1

    第1章 认识jQuery jQuery有以下优势: 轻量级: 强大的选择器: 出色的DOM操作的封装: 可靠的事件处理机制: 完善的Ajax: 不污染顶级变量: 出色的浏览器兼容性: 链式操作方式: ...

  8. javascript dom编程艺术笔记第三章:DOM操作的5个基本方法

    JavaScript的 DOM操作,主要是对DOM这三个字母中D.O.M的操作.D代表的是document(文档),即我们可以使用javascript对文档进行操作,O代表的是object(对象),对 ...

  9. JavaWeb学习笔记——jquery中的dom操作

     jquery中的dom操作 废话不说:直接上例子: 1.添加节点-html页面 Append:向每个匹配的元素内部追加内容. <body> <ul id="city& ...

随机推荐

  1. 20165234 《Java程序设计》第四周学习总结

    第四周学习总结 教材学习内容总结 第5章 子类与继承 子类的继承性 子类和父类在同一包中的继承性:子类继承父类中不是 private 的成员变量和方法作为自己的成员变量和方法 子类和父类不在同一包中的 ...

  2. java ==、equals、hashcode有什么区别

    1.== 用来比较两个对象的存储空间 2.equals是Object类提供的方法之一,每个java类都继承Object类,所以每一个对象都具有equals方法,所以在没有覆盖equals方法的情况下, ...

  3. Latex 编辑数学公式——快速上手

    参考链接: https://blog.csdn.net/fansongy/article/details/45368915 特殊符号: https://blog.csdn.net/caiandyong ...

  4. zookeeper安装教程

    zookeeper  一.单机安装 1.1 下载 1.2 安装 1.3 配置 1.4 启动和停止 二.伪集群模式 2.1 zookeeper1配置 2.2 zookeeper2配置 2.3 zooke ...

  5. python3编码(encode,decode)

    python3默认编码为unicode,由str类型进行表示.二进制数据使用byte类型表示. 字符串通过编码转换成字节码,字节码通过解码成为字符串 encode:str --> bytes d ...

  6. dubbo源码分析13——服务本地暴露 exportLocal(url)

    dubbo服务的本地暴露,显然是针对当服务消费者和服务提供者都在同一个jvm的进程内这种场景 .通常是发生在服务之间的调用的情况下.一种情况就是A服务调用B服务的情况,如果A服务和B服务都是在一个线程 ...

  7. VC常用小知识

    (1) 如何通过代码获得应用程序主窗口的 指针?主窗口的 指针保存在CWinThread::m_pMainWnd中,调用AfxGetMainWnd实现.AfxGetMainWnd() ->Sho ...

  8. u3d发送邮件

    http://gad.qq.com/article/detail/22810 https://www.douban.com/note/655356118/ http://gad.qq.com/arti ...

  9. Unity3D动态生成多边形

    来自https://blog.csdn.net/qq_14903317/article/details/69668521 自由绘制多边形   https://blog.csdn.net/lei_710 ...

  10. hibernate框架学习之数据抓取(加载)策略helloworld

    package cn.itcast.h3.query.hql; import java.util.List; import org.hibernate.Query; import org.hibern ...