一、DOM简介
DOM:Document Object Model 文档对象模型
要实现页面的动态交互效果,bom 操作远远不够,需要操作 html 才是核心。如何操作 htm,就是 DOM。简单的说,dom 提供了用程序动态控制 html 接口。DOM即文档对象模型描绘了一个层次化的节点树,运行开发人员添加、移除和修改页面的某一部分。dom 处于javascript 的核心地位上。
每个载入浏览器的 HTML 文档都会成为 Document 对象。Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问。Document 对象是 Window 对象的一部分,可通过 window.document 属性对其进行访问。
二、节点
加载 HTML 页面时,Web 浏览器生成一个树型结构,用来表示页面内部结构。DOM 将这种树型结构理解为由节点组成,组成一个节点树。对于页面中的元素,可以解析成以下几种类型的节点:
html –> 文档节点
div –> 元素节点
title –> 属性节点
测试 Div –> 文本节点
<html><head><title>树!树!到处都是树!</title></head><body><divtitle="属性节点">测试Div</div></body></html>
三、操作元素的节点
当HTML文档在被解析为一颗DOM树以后,里面的每一个节点都可以看做是一个一个的对象,我们称为DOM对象,对于这些对象,我们可以进行各式各样的操作,查找到某一个或者一类节点对象,可以创建某种节点对象,可以在某个位置添加节点对象,甚至可以动态地删除节点对象,这些操作可以使我们的页面看起来有动态的效果,后期结合事件使用,就能让我们的页面在特定时机、特定的事件下执行特定的变换。
1、获取节点
在进行增、删、改的操作时,都需要指定到一个位置,或者找到一个目标,此时我们就可以通过Document对象提供的方法,查找、定位某个对象(也就是我们说的节点)。
注意:操作 dom 必须等节点初始化完毕后,才能执行。
处理方式两种:
(1)把 script 调用标签移到html末尾即可;
(2)使用onload事件来处理JS,等待html 加载完毕再加载 onload 事件里的 JS。
window.onload = function () { //预加载 html 后执行};
获取方式如下:
<body><pid="p1"class="para">这是一个段落<span>文本</span><pid="p1"class="para">这又是一个段落</p><inputtype="text"name="txt"/><inputtype="checkbox"name="hobby"value="游泳"/>游泳<inputtype="checkbox"name="hobby"value="篮球"/>篮球<inputtype="checkbox"name="hobby"value="足球"/>足球<hr/><ahref="javascript:void(0)"onclick="testById()">按照id获取</a><ahref="javascript:void(0)"onclick="testByName()">按照name获取</a><ahref="javascript:void(0)"onclick="testByTagName()">按照标签名获取</a><ahref="javascript:void(0);"onclick="testByClass();">按照class获取</a></body>
说明:href=”javascript:void(0)”:伪协议,表示不执行跳转,而执行指定的点击事件。本文是Java大数据教程中JavaScript课程DOM部分的教学文档,如需全套视频课程和资料请评论留言或私聊。
<scripttype="text/javascript">// 按照id获取元素functiontestById(){// 返回单个对象varp=document.getElementById("p1");console.log(p);// 表示获取元素开始标签和结束标签之间的html结构console.log(p.innerHTML);console.log(p.innerText);// 表示获取标签之间的普通文本}// 按照name获取元素functiontestByName(){// 对象数组varho=document.getElementsByName("hobby");console.log(ho);for(vari=0;i<=ho.length-1;i++){console.log(ho[i].value);}}// 按照标签名获取元素functiontestByTagName(){// 对象数组varinputArr=document.getElementsByTagName("input");for(vari=0;i<inputArr.length;i++){if(inputArr[i].type=="text"){console.log("text类型");}elseif(inputArr[i].type=="checkbox"){if(inputArr[i].checked){console.log(inputArr[i].value);}}}}// 按照class属性获取元素functiontestByClass(){// 对象数组varps=document.getElementsByClassName("para");console.log(ps[0].innerHTML);ps[0].innerHTML+="这是一段新的文本";}</script>
四、创建节点和插入节点
很多时候我们想要在某个位置插入一个新的节点,此时我们首先需要有一个节点存在,可以通过以下几种方式创建新节点。
1、创建节点
2、插入节点
<buttononclick="add()">添加段落</button><divid="container"></div><scripttype="text/javascript">functionadd(){varcontainer=document.getElementById(container)varparagraph=document.createElement(p);vartxt=document.createTextNode(hello)paragraph.appendChild(txt)container.appendChild(paragraph)}</script>
添加 “段落、图片、文本框、选项”
如需全套java大数据架构教程和配套课件代码等资料请+V:xiaole888899999
3、间接查找节点
4、删除节点
removeChild():从元素中移除子节点
<scripttype="text/javascript">functiondelNode(){varprogrammer=document.getElementById("programmer");// 从父元素中删除节点,获取要删除对象的父元素,然后从父元素中删除该对象programmer.parentNode.removeChild(programmer);}</script><body><spanid="programmer">程序猿</span><ahref="javascript:void(0)"onclick="delNode();">删除</a></body>
声明:本文部分素材转载自互联网,如有侵权立即删除 。
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
丞旭猿论坛
暂无评论内容