CXYVIP官网源码交易平台_网站源码_商城源码_小程序源码平台-丞旭猿论坛
CXYVIP官网源码交易平台_网站源码_商城源码_小程序源码平台-丞旭猿论坛
CXYVIP官网源码交易平台_网站源码_商城源码_小程序源码平台-丞旭猿论坛

全新java大数据教程之JavaScript的DOM对象(DocumentObjectModel文档对象模型)-免费源码丞旭猿

一、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>

声明:本文部分素材转载自互联网,如有侵权立即删除 。

© 版权声明
THE END
喜欢就支持一下吧
点赞0赞赏 分享
相关推荐
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容