iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >JavaScript中HTML元素操作的示例分析
  • 193
分享到

JavaScript中HTML元素操作的示例分析

2024-04-02 19:04:59 193人浏览 泡泡鱼
摘要

小编给大家分享一下javascript中html元素操作的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、获取操作的元

小编给大家分享一下javascripthtml元素操作的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

一、获取操作的元素

document对象的方法和属性

document对象提供了一些用于查找元素的方法,利用这些方法可以根据元素的id、name和class属性以及标签名称的方式获取操作的元素。

JavaScript中HTML元素操作的示例分析

总结

除了document.getElementById()方法返回的是拥有指定id的元素外,其他方法返回的都是符合要求的一个集合。若要获取其中一个对象,可以通过下标的方式获取,默认从0开始。

document对象提供一些属性,可用于获取文档中的元素。例如,获取所有表单标签、图片标签等。

JavaScript中HTML元素操作的示例分析

JavaScript中HTML元素操作的示例分析

  • document对象的body属性用于返回body元素。

  • document对象的documentElement属性用于返回HTML文档的根节点html元素。

注意

通过document对象的方法与document对象的属性获取的操作元素表示的都是同一对象。如document.getElementsByTagName(‘body’)[0]与document.body全等。

JavaScript中HTML元素操作的示例分析

HTML5新增的document对象方法

HTML5中为更方便获取操作的元素,为document对象新增了两个方法,分别为querySelector()和querySelectorAll()。

  • querySelector()方法用于返回文档中匹配到指定的元素或CSS选择器的第1个对象的引用。

  • querySelectorAll()方法用于返回文档中匹配到指定的元素或CSS选择器的对象集合。

由于这两个方法的使用方式相同,下面以document.querySelector()方法为例演示。

Element对象的方法和属性

在DOM操作中,元素对象也提供了获取某个元素内指定元素的方法,常用的两个方法分别为getElementsByClassName()和getElementsByTagName()。它们的使用方式与document对象中同名方法相同。

JavaScript中HTML元素操作的示例分析

除此之外,元素对象还提供了children属性用来获取指定元素的子元素。例如,获取上述示例中ul的子元素。

JavaScript中HTML元素操作的示例分析

  • 元素对象的children属性返回的也是对象集合,若要获取其中一个对象,也需通过下标的方式获取,默认从0开始。

  • 另外,document对象中也有children属性,它的第一个子元素通常是html元素。

HTMLCollection对象

  • HTMLCollection对象:通过document对象或Element对象调用getElementsByClassName()方法、getElementsByTagName()方法、children属性等返回的对象集。

  • nodeList对象:document对象调用getElementsByName()方法在Chrome和FireFox浏览器中返回的是NodeList对象,IE11返回的是HTMLCollection对象。

HTMLCollection与NodeList对象的区别:

  • HTMLCollection对象用于元素操作。

  • NodeList对象用于节点操作。

提示:对于getElementsByClassName()方法、getElementsByTagName()方法和children属性返回的集合中可以将id和name自动转换为一个属性。

JavaScript中HTML元素操作的示例分析

二、元素内容

JavaScript中,若要对获取的元素内容进行操作,则可以利用DOM提供的属性和方法实现。

JavaScript中HTML元素操作的示例分析

  • 属性属于Element对象,方法属于document对象。

  • innerHTML在使用时会保持编写的格式以及标签样式。

  • innerText则是去掉所有格式以及标签的纯文本内容。

  • textContent属性在去掉标签后会保留文本格式。

举个例子

JavaScript中HTML元素操作的示例分析

代码实现

	<!DOCTYPE html>
	<html>
	<head>
	<meta charset="UTF-8">
	<title>元素内容操作</title>
	</head>
	<body>
	<p id="box">
	The first paragraph...
	<p>
	The second paragraph...
	<a href="Http://www.example.com">third</a>
	</p>
	</p>
	<script>
	var box = document.getElementById('box');
	console.log(box.innerHTML);
	console.log(box.innerText);
	console.log(box.textContent);
	</script>
	</body>
	</html>

注意

innerText属性在使用时可能会出现浏览器兼容的问题。因此,推荐在

开发时尽可能的使用innerHTML获取或设置元素的文本内容。同时,innerHTML属性和document.write()方法在设置内容时有一定的区别,前者作用于指定的元素,后者则是重构整个HTML文档页面。因此,读者在开发中要根据实际的需要选择合适的实现方式

【案例】改变盒子大小

JavaScript中HTML元素操作的示例分析

代码实现思路

① 编写HTML,设置p的大小。

② 根据用户的点击次数完成盒子大小的改变。

③ 单击的次数为奇数时,盒子都变大,单击次数为偶数时,盒子都变小。

代码实现

	<!DOCTYPE html>
	<html>
	<head>
	<meta charset="UTF-8">
	<style>
	.box{width:50px;height:50px;background:#eee;margin:0 auto;}
	</style>
	</head>
	<body>
	<p id="box" class="box"></p>
	<script>
	var box = document.getElementById('box');
	var i = 0; // 保存用户单击盒子的次数
	box.onclick = function() { // 处理盒子的单击事件
	++i;
	if (i % 2) { // 单击次数为奇数,变大
	this.style.width = '200px';
	this.style.height = '200px';
	this.innerHTML = '大';
	} else { // 单击次数为偶数,变小
	this.style.width = '50px';
	this.style.height = '50px';
	this.innerHTML = '小';
	}
	};
	</script>
	</body>
	</html>

三、元素属性

在DOM中,为了方便JavaScript获取、修改和遍历指定HTML元素的相关属性,提供了操作的属性和方法。

JavaScript中HTML元素操作的示例分析

利用attributes属性可以获取一个HTML元素的所有属性,以及所有属性的个数length。

举个例子

JavaScript中HTML元素操作的示例分析

代码实现

	<!DOCTYPE html>
	<html>
	<head>
	<meta charset="UTF-8">
	<title>元素属性操作</title>
	<style>
	.gray{background: #CCC;}
	#thick{font-weight: bolder;}
	</style>
	</head>
	<body>
	<p>test Word.</p>
	<script>
	// 获取p元素
	var ele = document.getElementsByTagName('p')[0];
	// ① 输出当前ele的属性个数
	console.log('未操作前属性个数:' + ele.attributes.length);
	// ② 为ele添加属性,并查看属性个数
	ele.setAttribute('align', 'center');
	ele.setAttribute('title', '测试文字');
	ele.setAttribute('class', 'gray');
	ele.setAttribute('id', 'thick');
	ele.setAttribute('style', 'font-size:24px;border:1px solid green;');
	console.log('添加属性后的属性个数:' + ele.attributes.length);
	// ③ 获取ele的style属性值
	console.log('获取style属性值:' + ele.getAttribute('style'));
	// ④ 删除ele的style属性,并查看剩余属性情况
	ele.removeAttribute('style');
	console.log('查看所有属性:');
	for (var i = 0; i < ele.attributes.length; ++i) {
	console.log(ele.attributes[i]);
	}
	</script>
	</body>
	</html>

四、元素样式

回顾:通过元素属性的操作修改样式。

元素样式语法:style.属性名称。

要求:需要去掉CSS样式名里的中横线“-”,并将第二个英文首字母大写。

举例:设置背景颜色的background-color,在style属性操作中,需要修改为backgroundColor。

JavaScript中HTML元素操作的示例分析

JavaScript中HTML元素操作的示例分析

注意

CSS中的float样式与JavaScript的保留字冲突,在解决方案上不同的浏览器

存在分歧。例如IE9——11、Chrome、FireFox可以使用“float”和“cssFloat”,Safari浏览器使用“float”,IE6~8则使用“styleFloat”。

问题:一个元素的类选择器可以有多个,在开发中如何对选择器列表进行操作?

原来的解决方案:利用元素对象的className属性获取,获取的结果是字符型,然后再根据实际情况对字符串进行处理。

HTML5提供的办法:新增的classList(只读)元素的类选择器列表。

举例:若一个p元素的class值为“box header navlist title”,如何删除header?

HTML5解决方案:p元素对象.classList.toggle(“header”);

举个例子

JavaScript中HTML元素操作的示例分析

代码实现

	<!DOCTYPE html>
	<html>
	<head>
	<meta charset="UTF-8">
	<title>classList的使用</title>
	<style>
	.bg{background:#ccc;}
	.strong{font-size:24px;color:red;}
	.smooth{height:30px;width:120px;border-radius:10px;}
	</style>
	</head>
	<body>
	<ul>
	<li>PHP</li>
	<li class="bg">JavaScript</li>
	<li>c++</li>
	<li>Java</li>
	</ul>
	<script> // 获取第2个li元素 var ele = document.getElementsByTagName('li')[1]; // 若li元素中没有strong类,则添加 if (!ele.classList.contains('strong')) { ele.classList.add('strong'); } // 若li元素中没有smooth类,则添加;若有删除 ele.classList.toggle('smooth'); console.log('添加与切换样式后:'); console.log(ele); </script>
	<script>
	ele.classList.remove('bg');
	console.log('删除后:');
	console.log(ele);
	</script>
	</body>
	</html>

除此之外,classList属性还提供了许多其他相关操作的方法和属性。

JavaScript中HTML元素操作的示例分析

五、【案例】标签栏切换效果

JavaScript中HTML元素操作的示例分析

代码实现思路

  • ① 编写HTML,实现标签栏的结构与样式的设计,其中class等于current表示当前显示的标签,默认是第一个标签。

  • ② 获取所有的标签与标签对应的显示内容。

  • ③ 遍历并为每个标签添加鼠标滑过事件,在事件的处理函数中,遍历标签对应的所有显示内容,当鼠标滑过标签时,通过classList的add()方法添加current,否则通过remove()方法移出current。

代码实现

	<!DOCTYPE html>
	<html>
	<head>
	<meta charset="UTF-8">
	<title>标签栏切换效果</title>
	<style>
	.tab-box{width:383px;margin:10px;border:1px solid #ccc;border-top:2px solid #206F96;}
	.tab-head{height:31px;}
	.tab-head-p{width:95px;height:30px;float:left;border-bottom:1px solid #ccc;border-right:1px solid #ccc;background:#206F96;line-height:30px;text-align:center;cursor:pointer;color:#fff;}
	.tab-head .current{background:#fff;border-bottom:1px solid #fff;color:#000;}
	.tab-head-r{border-right:0;}
	.tab-body-p{display:none;margin:20px 10px;}
	.tab-body .current{display:block;}
	</style>
	</head>
	<body>
	<p class="tab-box">
	<p class="tab-head">
	<p class="tab-head-p current">标签一</p>
	<p class="tab-head-p">标签二</p>
	<p class="tab-head-p">标签三</p>
	<p class="tab-head-p tab-head-r">标签四</p>
	</p>
	<!--jkdjfk?-->
	<p class="tab-body">
	<p class="tab-body-p current"> 1 </p>
	<p class="tab-body-p"> 2 </p>
	<p class="tab-body-p"> 3 </p>
	<p class="tab-body-p"> 4 </p>
	</p>
	</p>
	<script>
	// 获取标签栏的所有标签元素对象
	var tabs = document.getElementsByClassName('tab-head-p');
	// 获取标签栏的所有内容对象
	var ps = document.getElementsByClassName('tab-body-p');
	for (var i = 0; i < tabs.length; ++i) { // 遍历标签部分的元素对象
	tabs[i].onmouseover = function() { // 为标签元素对象添加鼠标滑过事件
	for (var i = 0; i < ps.length; ++i) { // 遍历标签栏的内容元素对象
	if (tabs[i] == this) { // 显示当前鼠标滑过的li元素
	ps[i].classList.add('current');
	tabs[i].classList.add('current');
	} else { // 隐藏其他li元素
	ps[i].classList.remove('current');
	tabs[i].classList.remove('current');
	}
	}
	};
	}
	</script>
	</body>
	</html>

以上是“JavaScript中HTML元素操作的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网VUE频道!

--结束END--

本文标题: JavaScript中HTML元素操作的示例分析

本文链接: https://www.lsjlt.com/news/97180.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中HTML元素操作的示例分析
    小编给大家分享一下JavaScript中HTML元素操作的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、获取操作的元...
    99+
    2024-04-02
  • JavaScript DOM元素常见操作的示例分析
    这篇文章主要介绍JavaScript DOM元素常见操作的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:DOM概念DOM(Document Object Model...
    99+
    2024-04-02
  • HTML脚本元素的示例分析
    这篇文章将为大家详细讲解有关HTML脚本元素的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 该<script>元素用于定义客户端脚本,例如HTML...
    99+
    2024-04-02
  • HTML元素定义的示例分析
    这篇文章将为大家详细讲解有关HTML元素定义的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 HTML 文档由 HTML 元素定义。 HTML 元素 开始标...
    99+
    2024-04-02
  • css定位html元素的示例分析
    这篇文章主要介绍css定位html元素的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!   定位值有五种类型:static(静态的)、relative(相对的)、fixed...
    99+
    2024-04-02
  • JavaScript中DOM操作的示例分析
    这篇文章主要介绍JavaScript中DOM操作的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:一、DOM概念1. "D":Docment,指的...
    99+
    2024-04-02
  • HTML元素实例分析
    今天小编给大家分享一下HTML元素实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 ...
    99+
    2024-04-02
  • HTML元素属性测试的示例分析
    这篇文章给大家分享的是有关HTML元素属性测试的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。code 元素的含义(语义)为“代码内容”,FireFox 在渲染该元素时,...
    99+
    2024-04-02
  • html中段落元素占用空间的示例分析
    这篇文章将为大家详细讲解有关html中段落元素占用空间的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 一系列的段落元素占用空间很是小的缘故原由,因为它们的所有...
    99+
    2024-04-02
  • html5中div与span html块级元素的示例分析
    这篇文章主要为大家展示了“html5中div与span html块级元素的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“html5中div与span h...
    99+
    2024-04-02
  • HTML中头部元素、字符实体的示例分析
    这篇文章将为大家详细讲解有关HTML中头部元素、字符实体的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   <head> 元素是所有头部元素的容器...
    99+
    2024-04-02
  • HTML块元素实例分析
    本文小编为大家详细介绍“HTML块元素实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“HTML块元素实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 大多数 HT...
    99+
    2024-04-02
  • HTML sidebar元素实例分析
    这篇文章主要介绍“HTML sidebar元素实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“HTML sidebar元素实例分析”文章能帮助大家解决问题。 ...
    99+
    2024-04-02
  • HTML5中的aside元素与article元素的示例分析
    本篇文章为大家展示了HTML5中的aside元素与article元素的示例分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。<aside>元素HTML&...
    99+
    2024-04-02
  • HTML5 Canvas像素操作的示例分析
    这篇文章给大家分享的是有关HTML5 Canvas像素操作的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 注意 由于人们可以直接操纵像素数据,因此出现了某些人利用从C...
    99+
    2024-04-02
  • JavaScript属性操作的示例分析
    这篇文章将为大家详细讲解有关JavaScript属性操作的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、属性的设置和获取1、属性的设置和获取主要有两种方式:<!DOCTYPE ...
    99+
    2023-06-29
  • JavaScript操作表单的示例分析
    这篇文章主要为大家展示了“JavaScript操作表单的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript操作表单的示例分析”这篇文章吧...
    99+
    2024-04-02
  • Javascript中DOM、节点和获取元素的示例分析
    这篇文章给大家分享的是有关Javascript中DOM、节点和获取元素的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。DOM文档:DOM中的“D”,当创建一个网页并把它加载到Web浏览器中时,它把编写的网...
    99+
    2023-06-25
  • HTML中浮动元素float使其父元素高度塌陷的示例分析
    这篇文章主要介绍HTML中浮动元素float使其父元素高度塌陷的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!浮动元素使其父元素高度塌陷我们经常会遇到一种情况,给一个元素设置浮动之后 float:left/r...
    99+
    2023-06-08
  • jquery对元素的基本操作实例分析
    jQuery简介 jQuery是JS的一个类库,对JS中的某些功能进行封装,让DOM操作变得简单,使代码简洁,易于使用,且支持链式写法,兼容性好。 jQuery的设计思想和主要用法即...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作