zoukankan      html  css  js  c++  java
  • javascript-02

    Document Object Model
    <code>

        var nodes = document.body;   /*获取到body的所有节点元素*/
        //console.info(nodes);

        for(var i=0;i<nodes.childNodes.length;i++){      /*nodes.childNodes获取到body下面的所有子节点*/
            console.info(nodes.childNodes[i].nodeName);   /*获取到的第一个节点是文本节点,因为br*/
        }


        /*获取到第一个子节点*/
        var oul = document.getElementById("ul1");
        var fc = oul.firstChild;    /*火狐 谷歌  文本   IE或li元素*/
        //alert(fc.nodeName + "  "+fc.nodeType);   //   li    text
        //console.info(fc.nodeName + "  "+fc.nodeType);
        var elementChild = oul.firstElementChild;
        console.info(elementChild.nodeName +" "+elementChild.nodeType);

        /*兼容性问题*/
        var elem = oul.firstElementChild || oul.firstChild;


        elem.style.backgroundColor = "red";



        /*获取到最后一个子节点*/
         var lastc = oul.lastElementChild || oul.lastChild;
        console.info(lastc.innerHTML);


        /*前一个兄弟节点*/
        var preSi = oul.lastElementChild.previousElementSibling;
        console.info(preSi);

        /*后一个兄弟节点*/
        var nenxtS = oul.nextElementSibling;
        console.info(nenxtS);



        /*得到父节点*/
        var odiv2 = document.getElementById("div2");
        var parentn = odiv2.parentNode;
        console.info(parentn.id);

        var odiv3 = document.getElementById("div3");
        var offsetp = odiv3.offsetParent;
        console.info(offsetp.id);

        /*获取属性节点,获取到属性后加入到集合里面是倒叙*/
        var odiv1 = document.getElementById("div1");
        var attArr = odiv1.attributes;
        console.info(attArr.length);
        console.info(attArr[0]);
        console.info(attArr[1]);
        console.info(attArr[2]);

        console.info(odiv1.id);  /*直接通过对象获取到属性*/
        odiv1.title = "divmodel";   /*自定义属性*/
        odiv1.setAttribute("value","test");

        odiv1.removeAttribute('title');   /*删除属性*/

        /*nodevalue*/
        var op = document.getElementById("p1");
        var value = op.firstChild.nodeValue;   /*nodevalue只适用于文本节点*/
        console.info(value);

        /*创建一个节点,并且增加到网页里面*/
        var op1 = document.createElement("p");  /*创建好了p元素*/
        op1.innerHTML = "增加的p元素";

        odiv3.appendChild(op1);

        var ospan = document.getElementById("span1");
        //odiv3.insertBefore(op1,ospan);   /*指定放在那个元素的前面*/

        //var op2 = document.createElement("p");  /*创建好了p元素*/
        /*var otext = document.createTextNode("这是创建的文本内容");
        op1.firstChild.appendData(otext);
        odiv3.appendChild(op1);*/

    </code>





    <code>  

        var oul = document.getElementById("ul1");
        var oli = oul.firstElementChild;
        var text = document.createTextNode("今天赢球了");
        oli.firstChild.appendData("今天赢球了");   /*默认增加内容放在后面*/
        oli.firstChild.insertData(2,"##");   /*增加文本内容放在指定的位置*/
        oli.firstChild.deleteData(0,4);   /*删除文本内容,第一个参数指定了参数的位置,第二个参数指定删除长度*/
        oli.firstChild.replaceData(0,0,"**");  /*第一个参数是起始位置,第二个参数长度,第三个参数替换内容*/
        console.info(oli.firstChild);

        var textNode = document.createTextNode("这是创建的文字");  /*这是创建的文本节点*/
        oli.appendChild(textNode);
    </code>

  • 相关阅读:
    restful风格 webapi 发送put delete请求 405 错误
    mysql 连接数据库间接性连接异常
    .net core 发布到centos The configuration file 'appsettings.json' was not found and is not optional. 找不到文件
    .net list<int>、int[]参数类型 前端调用传参方法
    long? long 可空类型转换
    EF 多对多循环引用序列化失败 解决办法
    HTML5学习之HTML标记类型
    电脑高手常用的5个按钮!(太有用了!留下了!)
    final关键字用法总结
    Java程序员面试失败的5大原因 //转自:极客网
  • 原文地址:https://www.cnblogs.com/JLeeci/p/5528622.html
Copyright © 2011-2022 走看看