DOM对象

核心DOM

Document:文档对象

创建(获取)

在html dom模型中可以使用window对象来获取
1. window.document
2. document

方法

  1. 获取Element对象:
    1. getElementById() : 根据id属性值获取元素对象。id属性值一般唯一
    2. getElementsByTagName():根据元素名称获取元素对象们。返回值是一个数组
    3. getElementsByClassName():根据Class属性值获取元素对象们。返回值是一个数组
    4. getElementsByName(): 根据name属性值获取元素对象们。返回值是一个数组

  2. 创建其他DOM对象:
    createAttribute(name)
    createComment()
    createElement()
    createTextNode()

Element:元素对象

	1. 获取/创建:通过document来获取和创建
	2. 方法:
			1. removeAttribute():删除属性
			2. setAttribute():设置属性
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>document对象</title>
</head>
<body>
<!--
<div id="div1">div1</div>
<div id="div2">div1</div>
<div class="cls1">div3</div>
<div class="cls1">div3</div>
<input type="text" name="username">
-->
<!--<input type="text" name="username">
<input type="button"id="btn_set" value="设置属性">
<input type="button" id="btn_remove" value="删除属性">
<a>点我试一试</a>-->
<div id =div1>
    <div id="div2">div2</div>
    div1
</div>
<a href="javascript:void(0);" id="del">删除子节点</a>
<a href="javascript:void(0);" id="add">添加子节点</a>
<script>
    //var divs=document.getElementsByTagName("div");
   /* var btn_set=document.getElementById("btn_set");
    btn_set.onclick=function (qualifiedName, value) {
        var elment_a=document.getElementsByTagName("a")[0];
        elment_a.setAttribute("href","https://www.baidu.com")
    }*/
    //1、获取超链接
    var element_a=document.getElementById("del")
    //2、绑定单击事件
    element_a.onclick=function () {
        var div1=document.getElementById("div1");
        var div2=document.getElementById("div2");
        div1.removeChild(div2);
    }

    var div2=document.getElementById("div2");
    var div1=div2.parentNode;
    alert(div1)

</script>
</body>
</html>

Node:节点对象(其他5个的父对象)

 **特点**:所有dom对象都可以被认为是一个节点
	**方法**:
			* CRUD dom树:
				* appendChild():向节点的子节点列表的结尾添加新的子节点。
				* removeChild()	:删除(并返回)当前节点的指定子节点。
				* replaceChild():用新节点替换一个子节点。
		**属性**:
			* parentNode 返回节点的父节点。

HTML DOM

	1. 标签体的设置和获取:innerHTML
	2. 使用html元素对象的属性
	3. 控制元素样式
		1. 使用元素的style属性来设置
			如:
				 //修改样式方式1
		        div1.style.border = "1px solid red";
		        div1.style.width = "200px";
		        //font-size--> fontSize
		        div1.style.fontSize = "20px";
		2. 提前定义好类选择器的样式,通过元素的className属性来设置其class属性值。

Exercise

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>动态表格</title>
</head>
<body>
<div>
    <input type="text" id="id" placeholder="请输入编号">
    <input type="text" id="name" placeholder="请输入姓名">
    <input type="text" id="gender" placeholder="请输入性别">
    <input type="button" id="btn_add" value="添加">
</div>

<table border="1" width="50%">
    <caption>学生信息表</caption>
    <tr>
        <th>编号</th>
        <th>姓名</th>
        <th>性别</th>
        <th>操作</th>
    </tr>

    <tr>
        <td>1</td>
        <td>令狐冲</td>
        <td></td>
        <td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td>
    </tr>

    <tr>
        <td>2</td>
        <td>任我行</td>
        <td></td>
        <td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td>
    </tr>

    <tr>
        <td>3</td>
        <td>岳不群</td>
        <td></td>
        <td><a href="javascript:void(0);" onclick="delTr(this);" >删除</a></td>
    </tr>


</table>
<script>
    /*分析:
    1、添加:
       1、给添加按钮绑定单击事件
       2、获取文本框内容
       3、创建td,设置td的文本为文本框的内容
       4、创建tr
       5、将tda添加到tr中
       6、获取table,将tr添加到table中
    2、删除
       1、确定点击是哪一个超链接
          <a href="javascript:void();οnclick="delTr(this);">删除</a>
       2、怎么删除
           removeChild();通过父节点删除子节点
       */

    //1、获取按钮
    /*document.getElementById("btn_add").οnclick=function () {
        //2、获取文本框内容
        var id =document.getElementById("id").value;

        var name =document.getElementById("name").value;
        var gender =document.getElementById("gender").value;
        //3、创建td 赋值td的标签体
        //id 的td
        var td_id=document.createElement("td");
        var text_id=document.createTextNode(id);
        td_id.append(text_id);
        //name
        var td_name=document.createElement("td");
        var text_name=document.createTextNode(name);
        td_name.append(text_name);
        //gender
        var td_gender=document.createElement("td");
        var text_gender=document.createTextNode(gender);
        td_gender.append(text_gender);
        //a标签
        var td_a = document.createElement("td");
        var ele_a=document.createElement("a");
        ele_a.setAttribute("href","javascript:void()");
        ele_a.setAttribute("onclick","delTr(this)")
        var text_a=document.createTextNode("删除");
        ele_a.appendChild(text_a);
        td_a.appendChild(ele_a);

       //4、创建tr
        var tr=document.createElement("tr");
        //5、添加tr到td中
        tr.appendChild(td_id);
        tr.appendChild(td_name);
        tr.appendChild(td_gender);
        tr.appendChild(td_a);
        //6、获取table
        var table=document.getElementsByTagName("table")[0];
        table.appendChild(tr);

    }*/
    //用innerHTML添加
    document.getElementById("btn_add").οnclick=function () {
        //获取文本框的内容
        var id=document.getElementById("id").value;
        var name=document.getElementById("name").value;
        var gender=document.getElementById("gender").value;
        //获取table
        var table=document.getElementsByTagName("table")[0];
        table.innerHTML += "<tr>\n" +
            "<td>"+id+"</td>\n" +
            "<td>"+name+"</td>\n" +
            "<td>"+gender+"</td>\n" +
            "<td><a href=\"javascript:void(0);\" onclick=\"delTr(this);\" >删除</a></td>\n" + "    </tr>";
    }

     function delTr(obj) {
        var table=obj.parentNode.parentNode.parentNode;
        var tr=obj.parentNode.parentNode;
        table.removeChild(tr);
     }

</script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值