手记

JavaScript学习笔记

JavaScript学习笔记

mirindaRain关注0人评论143人阅读2018-09-26 17:28:04

本课程对应的视频地址:http://edu.51cto.com/course/15019.html

1、DOM

DOM:Document Object Model

mark

1.1、W3C规定的三类DOM标准接口

Core DOM(核心DOM),适用于各种结构化文档

XML DOM,专用于XML文档

HTML DOM,专用于HTML文档(了解)

1.2、Core DOM

1.2.1、查找dom

document.getElementById("id"):根据id元素来查找某个对象

document.getElementsByTagName("tag"):根据标签来获取元素-->数组

document.getElementsByName("name"):根据name来获取元素-->数组

nextElementSibling:下一个元素节点

previousElementSibling:上一个元素节点

childNode:子节点(包含文本节点)

children:子元素节点

childElementCount:子元素的数量

lastElementChild:最后一个元素节点

firstElementChild:第一个元素节点

firstChild:第一个节点

lastChild:最后一个节点

nodeType:节点的类型

    元素节点:1

    属性节点:2

    文本节点:3

parentNode:父节点

案例:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <script type="text/javascript">

        function changeImg(){

            var imgObject = document.getElementById("myimg");

            imgObject.src="../images/2.jpg";

        }

        function getData(){

            var seasons = document.getElementsByName("season");

            var str= "";

            for(var i = 0 ;i<seasons.length;i++) {

                str=str+seasons[i].value+"<br/>";

            }

            document.getElementById("result").innerHTML=str;

        }

        function getInputData(){

            var inputs = document.getElementsByTagName("input");

            var str= "";

            for(var i = 0 ;i<inputs.length;i++) {

                str=str+inputs[i].value+"<br/>";

            }

            document.getElementById("result").innerHTML=str;

        }

    </script>

</head>

<body>

    <img src = "../images/1.jpg" id = "myimg"/>

    <input type="button" value="修改图片" onclick="changeImg()"/>

    <input type="text" value="春" name="season"/>

    <input type="text" value="夏" name="season"/>

    <input type="text" value="秋" name="season"/>

    <input type="text" value="东" name="season"/>

    <input type="button" value="得到季节" onclick="getData()"/>

    <input type="button" value="获取所有的input标签的内容" onclick="getInputData()"/>

    <div id = "result">

    </div>

</body>

</html>

也可以通过setAttribute(attr,value)设置对象的属性

imgObject.setAttribute("src","../images/2.jpg");

imgObject.setAttribute("onclick","myFun()");

那么如果想获取属性的值,就可以通过getAttribute("name")来获取

如果我们想对对象加样式,通过object.style属性操作

  <script type="text/javascript">

        window.onload = function(){

            var box = document.getElementById("box");

            box.style.border="1px solid red";

            box.style.backgroundColor="#ccc";

            box.style.width="300px";

            box.style.height="300px";

        }

    </script>

1.2.2、dom的创建相关操作

案例:

<script type="text/javascript">

        window.onload = function(){

            var div = document.createElement("div");

            div.style.width="400px";

            div.style.height="400px";

            div.style.border="1px solid red";

            document.body.appendChild(div);

            var input = document.createElement("input") ;

            input.setAttribute("type","text");

            input.setAttribute("value","zhangsan");

            div.appendChild(input);

        }

    </script>

与dom相关操作有哪些呢?

createElement:创建一个元素节点

appendChild:将这个元素加入某个元素内部

insertBefore(在某个节点前面插入新的节点):parentElement.insertBefore(newNode,thisNode)

cloneNode:克隆,有一个参数,默认是false,当为true表示深克隆(连同子节点一起克隆)

案例2:插入兄弟节点

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <script type="text/javascript">

        window.onload=function (ev) {

            var cc = document.getElementById("cc");

            var li = document.createElement("li");

            li.innerHTML="貂蝉";

            //insertBefore(newNode,已经存在的节点)

            document.body.insertBefore(li,cc);

        }

    </script>

</head>

<body>

    <li>关羽</li>

    <li id="cc">曹操</li>

    <li>狂铁</li>

</body>

</html>

案例3:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <script type="text/javascript">

        function copy(){

            var img = document.getElementById("id01");

            var newImg = img.cloneNode();

            document.body.insertBefore(newImg,img);

        }

        function copyul(){

            var myul = document.getElementById("myul");

            document.body.appendChild(myul.cloneNode(true));

        }

    </script>

</head>

<body>

    <img id = "id01" src = "../images/1.jpg"/>

    <input type="button" onclick="copy()" value="复制"/>

    <ul id="myul">

        <li>关羽</li>

        <li>盾山</li>

    </ul>

    <input type="button" onclick="copyul()" value="复制ul"/>

</body>

</html>

1.2.3、删除和替换操作

removeChild:删除某个子节点

replaceChild(new,old):新的替换旧的节点

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <script type="text/javascript">

        function myremove(){

            var img = document.getElementById("id02");

            document.body.removeChild(img);

        }

        function myreplace(){

            var img = document.getElementById("id01");

            var newImg = document.createElement("img");

            newImg.setAttribute("src","../images/5.jpg");

            document.body.replaceChild(newImg,img);

        }

    </script>

</head>

<body>

<img id = "id01" src = "../images/1.jpg"/>

<img id = "id02" src = "../images/2.jpg"/>

<img id = "id03" src = "../images/3.jpg"/>

<input type="button" onclick="myremove()" value="移除"/>

<input type="button" onclick="myreplace()" value="替换操作"/>

</body>

</html>

1.3、练习

1.3.1、隔行变色

<script type="text/javascript">

            window.onload=function(){

                var trs = document.getElementsByTagName("tr");

                for(var i = 0 ;i<trs.length;i++) {

                    if(i%2==0) {

                        trs[i].style.backgroundColor="#ccc";

                    }

                }

            }

    </script>

高亮显示

 <script type="text/javascript">

            window.onload=function(){

                var trs = document.getElementsByTagName("tr");

                //onmouseover :鼠标经过

                //onmouseout:鼠标离开

                for(var i = 0 ;i<trs.length;i++) {

                    trs[i].onmouseover=function(){

                        this.style.backgroundColor='#ccc';

                    };

                    trs[i].onmouseout=function(){

                        this.style.backgroundColor='white';

                    }

                }

            }

    </script>

1.3.2、实现全选,反选等效果

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title></title>

    <script type="text/javascript">

        window.onload=function(){

            var allObject = document.getElementById("all");

            var allHobbies = document.getElementsByName("hobby");

            //全选效果

            allObject.onclick=function(){

                for(var i = 0 ;i<allHobbies.length;i++) {

                    allHobbies[i].checked=this.checked;

                }

            }

            for(var i = 0;i<allHobbies.length;i++) {

                allHobbies[i].onclick=function(){

                   allObject.checked=checkAll();

                }

            }

            var fanObject = document.getElementById("fan");

            fanObject.onclick=function(){

                for(var i = 0;i<allHobbies.length;i++) {

                    allHobbies[i].checked=!allHobbies[i].checked;

                }

                //判断是否全部选中

                allObject.checked=checkAll();

            }

        }

        function checkAll(){

            var allHobbies = document.getElementsByName("hobby");

            var flag = true;

            for(var i = 0;i<allHobbies.length;i++) {

                if(allHobbies[i].checked==false){

                    flag=false;

                    break;

                }

            }

            return flag ;

        }

    </script>

</head>

<body>

<input type="checkbox" id="all"/>全选 <input type="checkbox" id="fan"/>反选<br/>

<hr/>

<input type="checkbox" name="hobby">关羽<br/>

<input type="checkbox" name="hobby">曹操<br/>

<input type="checkbox" name="hobby">貂蝉<br/>

</body>

</html>

1.3.3、动态编写一个表格

mark

案例实现:

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <script type="text/javascript">

        var table ;

        var thead ;

        var tbody;

        window.onload = function(){

            createTable();

            createTheadData();

            createTbodyData();

        }

        function createTable(){

            table  = document.createElement("table");

            //将table加入到body中

            document.body.appendChild(table);

            thead  = document.createElement("thead");

            //将thead加入了table中

            table.appendChild(thead);

            tbody = document.createElement("tbody");

            table.appendChild(tbody);

            //为table元素添加相关关属性

            table.setAttribute("border","1");

            table.setAttribute("width","100%");

        }

        function createTheadData(){

            //向thead中插入了一行

            var tr = thead.insertRow();

            //tr我需要添加单元格

            var td_id = tr.insertCell();

            td_id.innerHTML="编号";

            var td_name = tr.insertCell();

            td_name.innerHTML="姓名";

            var td_oper = tr.insertCell();

            td_oper.innerHTML="数据操作";

        }

        //生成10条数据

        function createTbodyData(){

            for(var i = 0 ;i<10;i++) {

                var tr = tbody.insertRow();

                var td_id = tr.insertCell();

                td_id.innerHTML=i;

                var td_name = tr.insertCell();

                td_name.innerHTML="张"+i;

                var td_oper = tr.insertCell();

                td_oper.innerHTML='<input type="button" onclick="mydelete(this)" value = "删除"/><input type="button" onclick="updatePre(this)" value = "修改"/>';

            }

        }

        function mydelete(obj) {

            if(confirm('确定删除此行吗')) {

                var tr = obj.parentNode.parentNode;

                var rowIndex = tr.rowIndex-1;

                tbody.deleteRow(rowIndex);

            }

        }

        /*

        *   需要将数据区改为可编辑状态(input)

        *   按钮部分变成确定和取消

        * */

        function updatePre(obj) {

            var td = obj.parentNode ;

            var td_name = td.previousElementSibling;

            var td_id = td.previousElementSibling.previousElementSibling;

            var id = td_id.innerHTML;

            var name = td_name.innerHTML;

            //在js中可以为对象动态添加属性

            td_name.tag=name;

            td_id.tag=id;

            td_name.innerHTML="<input type='text' value='"+name+"'/>";

            td_id.innerHTML="<input type='text' value = '"+id+"'/>";

            //改变数据操作区的按钮

            var btn_confirm = document.createElement("input");

            btn_confirm.setAttribute("type","button");

            btn_confirm.setAttribute("value","确定");

            btn_confirm.setAttribute("onclick","confirmData(this)");

            var btn_cancel = document.createElement("input");

            btn_cancel.setAttribute("type","button");

            btn_cancel.setAttribute("value","取消");

            btn_cancel.setAttribute("onclick","myCancel(this)")

            td.innerHTML="" ;

            td.appendChild(btn_confirm);

            td.appendChild(btn_cancel);

        }

        function myCancel(obj){

            var td = obj.parentNode ;

            var td_name = td.previousElementSibling;

            var td_id = td.previousElementSibling.previousElementSibling;

            td_id.innerHTML=td_id.tag;

            td_name.innerHTML=td_name.tag;

            //还原最后一个td

            td.innerHTML='<input type="button" onclick="mydelete(this)" value = "删除"/><input type="button" onclick="updatePre(this)" value = "修改"/>';

        }

        /*

          id,name必须要非空

        * id不能重复

        * */

        function confirmData(obj) {

            //确定

            var td = obj.parentNode ;

            var td_name = td.previousElementSibling;

            var td_id = td.previousElementSibling.previousElementSibling;

            //首先获取用户输入的值

            var name  = td_name.getElementsByTagName("input")[0].value;

            var id  = td_id.getElementsByTagName("input")[0].value;

            if(name==""||id=="") {

                alert("对不起,数据不能为空");

                return ;

            }

            //判断ID不能重复

            if(isSame(id)) {

                alert("对不起,id不能重复");

                return  ;

            }

            //验证都通过了,那么接下来就是将数据真正的放在单元格中

            td_name.innerHTML=name;

            td_id.innerHTML=id;

            td.innerHTML='<input type="button" onclick="mydelete(this)" value = "删除"/><input type="button" onclick="updatePre(this)" value = "修改"/>';

        }

        function isSame(id){

            var flag = false;

            for(var i = 0 ;i<tbody.rows.length;i++) {

                var tr = tbody.rows[i];

                if(id==tr.firstElementChild.innerHTML) {

                    flag = true

                    break;

                }

            }

            return flag ;

        }

    </script>

</head>

<body>

</body>

</html>

总结:

table对象:

rows属性

insertRow():插入一行

deleteRow():删除一行

tableRow对象:行对象

cells:单元格对象

rowIndex:行号

insertCell():插入单元格

deleteCell():删除单元格

TableCell对象:每个单元格

cellIndex:单元格的索引

©著作权归作者所有:来自51CTO博客作者mirindaRain的原创作品,如需转载,请注明出处,否则将追究法律责任


0人推荐
随时随地看视频
慕课网APP