<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. MySql cmd下的学习笔记 —— 有关视图的操作(algorithm)

    建立一张简单的查询视图,不用临时表,只用条件合并 在简单的查询中,建立临时表的开销比较大 这是可以指定algorithm选项为merge 在v2的视图中,并没有建立临时表 但在下列情况下,必须建立临时 ...

  2. 为了确认是您本人在申请搬家,请在原博客发表一 篇标题为《将博客搬至CSDN》的文章,并将文章地址填写在上方的"搬家通知地址"中

    为了确认是您本人在申请搬家,请在原博客发表一 篇标题为<将博客搬至CSDN>的文章,并将文章地址填写在上方的"搬家通知地址"中

  3. Yara VS2017出现LINK : fatal error LNK1104: 无法打开文件“msvcrt.lib”

    解决方法1 搜索msvcrt.lib所在的路径 C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MS ...

  4. 【转】python 内置函数总结(大部分)

    [转]python 内置函数总结(大部分) python 内置函数大讲堂 python全栈开发,内置函数 1. 内置函数 python的内置函数截止到python版本3.6.2,现在python一共为 ...

  5. 【转】python之random模块分析(一)

    [转]python之random模块分析(一) random是python产生伪随机数的模块,随机种子默认为系统时钟.下面分析模块中的方法: 1.random.randint(start,stop): ...

  6. python中“*”、"*args"、"kwargs"三种用法

    参考链接:https://www.cnblogs.com/cwind/p/8996000.html 注意的是: (1)"*"符号的用法很类似C++中的指针,针对列表; (2)&qu ...

  7. vsftp、ftps 搭建

    今天公司某个产品预上线,该产品需要向政府某部门提供一些数据. 该部门提交数据需要使用ftps,苦逼的我只能是测试环境搭建一套,用来测试提交数据. 先自行科普下ftps. 一.搭建vsftp 安装vsf ...

  8. 自学MVC看这里——全网最全ASP.NET MVC 教程汇总(转)

    自学MVC看这里——全网最全ASP.NET MVC 教程汇总   MVC架构已深得人心,微软也不甘落后,推出了Asp.net MVC.小编特意整理博客园乃至整个网络最具价值的MVC技术原创文章,为想要 ...

  9. http 遇到中文表单 转码

    #include <string> #include <vector> inline BYTE toHex(const BYTE x) { return x>9?x+55 ...

  10. RF运行脚本报错:WebDriverException: Message: unknown error: call function result missing

    原因:浏览器驱动与浏览器版本不对应