JavaScript实例详解之HTML元素操作

本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了关于html元素操作的相关问题,包括了怎么获取操作的元素、操作元素的内容、元素的属性以及样式等等,希望对大家有帮助。

JavaScript实例详解之HTML元素操作

相关推荐:javascript教程

一、获取操作的元素

 document对象的方法和属性

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

在这里插入图片描述

立即学习“Java免费学习笔记(深入)”;

总结

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

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

在这里插入图片描述

在这里插入图片描述

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

注意

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

在这里插入图片描述

HTML5新增的document对象方法

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

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

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

 Element对象的方法和属性

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

在这里插入图片描述

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

在这里插入图片描述

元素对象的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中,若要对获取的元素内容进行操作,则可以利用DOM提供的属性和方法实现。

在这里插入图片描述

属性属于Element对象,方法属于document对象。innerHTML在使用时会保持编写的格式以及标签样式。innerText则是去掉所有格式以及标签的纯文本内容。textContent属性在去掉标签后会保留文本格式。

举个例子

在这里插入图片描述

代码实现

元素内容操作

The first paragraph...

The second paragraph...third

var box = document.getElementById('box');console.log(box.innerHTML);console.log(box.innerText);console.log(box.textContent);

注意

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

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

【案例】改变盒子大小

在这里插入图片描述

代码实现思路

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

腾讯元宝 腾讯元宝

腾讯混元平台推出的AI助手

腾讯元宝 223 查看详情 腾讯元宝

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

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

代码实现

.box{width:50px;height:50px;background:#eee;margin:0 auto;}

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 = '小';}};

三、元素属性

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

在这里插入图片描述

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

举个例子

在这里插入图片描述

代码实现

元素属性操作.gray{background: #CCC;}#thick{font-weight: bolder;}

test word.

// 获取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]);}

四、元素样式

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

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

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

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

在这里插入图片描述

在这里插入图片描述

注意

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”);

举个例子

在这里插入图片描述

代码实现

classList的使用.bg{background:#ccc;}.strong{font-size:24px;color:red;}.smooth{height:30px;width:120px;border-radius:10px;}
  • PHP
  • JavaScript
  • C++
  • Java
// 获取第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); ele.classList.remove('bg');console.log('删除后:');console.log(ele);

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

在这里插入图片描述

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

在这里插入图片描述

代码实现思路

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

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

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

代码实现

标签栏切换效果.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;}

标签一

标签二

标签三

标签四

1

2

3

4

// 获取标签栏的所有标签元素对象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');}}};}

相关推荐:javascript教程

以上就是JavaScript实例详解之HTML元素操作的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/551927.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 20:34:25
下一篇 2025年11月9日 20:34:58

相关推荐

  • Web 2.0和Web 3.0有什么区别?一文带你搞懂两者的区别

    从互联网诞生至今,我们经历了从静态信息展示到动态交互的巨大变迁。Web 2.0时代,也就是我们当前所处的互联网环境,其核心特征是互动性和用户生成内容。社交媒体、博客、维基百科等都是Web 2.0的典型产物,它们将用户从单纯的信息接收者转变为内容的创造者和传播者。而Web 3.0则代表了一种新的网络范…

    2025年12月11日
    000
  • 什么是去中心化应用程序 (dApp)?一文通俗解释中心化应用程序 (dApp)

    在理解去中心化应用程序(dApp)之前,我们有必要先了解我们日常接触的绝大多数应用程序,它们被称为中心化应用程序。我们手机上使用的社交媒体、购物平台、银行应用等,都属于中心化应用。这类应用的特点是其所有的数据和运营逻辑都储存在由某个公司或组织控制的中心服务器上。 这个中心化的实体拥有绝对的控制权,可…

    2025年12月11日
    000
  • 异步加载:优化PHP页面性能,先显示部分内容再加载耗时函数结果

    第一段引用上面的摘要: 本文旨在解决PHP页面中耗时函数阻塞页面渲染的问题。通过采用客户端异步加载技术(如AJAX),实现在页面初始加载时先显示主要内容,然后通过异步请求获取耗时函数的结果,并动态插入到页面中,从而显著提升用户体验。 当PHP脚本执行时,服务器会按照代码顺序执行,并将最终结果发送给客…

    2025年12月11日
    000
  • 异步加载:先显示页面主体,再插入耗时函数结果

    本文介绍了一种使用客户端渲染(如 AJAX)解决 PHP 页面中耗时函数导致页面加载缓慢的问题。通过将耗时函数的执行放在客户端,可以先快速显示页面的主体内容,然后异步加载耗时函数的结果,从而提升用户体验。本文将详细讲解如何使用 AJAX 实现这一目标,并提供示例代码供参考。 PHP 是一种服务器端语…

    2025年12月11日 好文分享
    000
  • 优化页面加载速度:先显示部分内容,再异步加载耗时函数结果

    摘要 本文将探讨如何优化网页加载体验,特别是在页面包含需要较长时间执行的函数时。我们将介绍一种利用 AJAX 技术,先快速呈现页面的主要内容,然后异步加载耗时函数结果的方法,有效提升用户感知速度和整体用户体验。这种策略避免了用户长时间的空白等待,使页面交互更加流畅。 正文 传统的 PHP 页面渲染方…

    2025年12月11日 好文分享
    000
  • PHP怎么调试代码_PHP代码调试环境配置教程

    答案:PHP调试核心是配置Xdebug并与IDE集成,辅以日志和变量打印。需正确安装Xdebug,修改php.ini设置xdebug.mode=debug等参数,重启服务后在VS Code或PhpStorm中监听端口,配合浏览器插件实现断点调试;常见问题包括配置路径错误、版本不兼容、端口冲突等,可通…

    2025年12月11日
    000
  • PHP如何将对象转换为数组_PHP对象与数组之间的类型转换方法

    对象转数组可用(array)、json_encode/json_decode或get_object_vars,分别处理不同属性可见性;数组转对象可用(object)或json_encode/json_decode,自定义类需构造函数或工厂方法。 PHP中将对象转换为数组,或将数组转换为对象,这在数据…

    2025年12月11日
    000
  • PHP代码注入检测人工智能应用_人工智能在代码注入检测中的应用

    AI通过静态分析、动态污点追踪、智能模糊测试和运行时监控提升PHP代码注入检测精度,有效识别SQL注入、命令注入、XSS等漏洞,结合CodeBERT、LSTM、强化学习等技术优化检测模型,并以准确率、召回率、误报率和F1-score等指标评估效果,但面临数据集不足、对抗攻击和可解释性差等挑战,未来将…

    2025年12月11日
    000
  • Laravel 中表单提交后如何保持下拉列表的选中状态

    本文旨在解决 Laravel 应用中表单提交后下拉列表(select)重置的问题。通过利用 Laravel 提供的 request 对象和旧输入值功能,我们能够轻松地在页面刷新后保持用户在下拉列表中选择的选项,从而提升用户体验。本文将详细介绍如何在视图中正确地处理下拉列表的选中状态,并提供相应的代码…

    2025年12月11日
    000
  • Laravel 中下拉列表选择后重置问题的解决

    本文旨在解决 Laravel 应用中下拉列表在提交后重置的问题。通过利用 Laravel 的请求对象,我们将演示如何在页面刷新后保持用户在下拉列表中选择的选项,从而提升用户体验。文章将提供详细的代码示例和解释,帮助开发者轻松实现该功能。 在 Laravel 应用中,经常会遇到需要在表单提交后保持用户…

    2025年12月11日
    000
  • PHP如何验证电子邮件地址格式_PHP校验电子邮件地址有效性的方法

    答案:PHP验证电子邮件需结合格式校验与安全性处理。首先使用filter_var()或正则检查基本格式,再通过dns_get_record()验证域名MX记录以确认存在性;为防安全漏洞,应转义输入特殊字符并用预处理语句防止SQL注入;提升体验可实现实时验证与清晰错误提示;对含非ASCII字符的国际化…

    2025年12月11日 好文分享
    000
  • php如何实现页面跳转?php页面重定向的几种实现方式

    PHP页面跳转推荐使用header()函数,因其基于HTTP协议的Location头部实现服务器端重定向,效率高、SEO友好且控制力强。通过header(‘Location: URL’, true, 状态码)可指定301(永久)、302(临时)或303等状态码,精准影响搜索引…

    2025年12月11日
    000
  • PHP怎么获取文件大小_PHP获取文件大小并格式化显示

    PHP中获取文件大小需使用filesize()函数,返回字节数,结合formatBytes函数可转换为KB、MB等易读单位。该函数通过log计算数量级,支持精度控制与单位扩展,适用于本地文件但不支持远程URL。需注意权限、文件存在性及32位系统对大文件的限制。实际应用中常用于上传校验,需前后端协同判…

    2025年12月11日
    000
  • 解决AJAX中FormData与额外数据传递难题

    本文旨在解决在使用jQuery AJAX结合FormData进行文件上传时,如何正确地传递额外变量(如ID)到服务器端的问题。我们将深入探讨常见错误及其原因,并提供一个安全高效的解决方案,即通过FormData.append()方法将所有数据统一封装,确保服务器能够正确接收。此外,文章还将强调并提供…

    2025年12月11日
    100
  • 使用 AJAX 上传文件时传递额外数据的方法

    本文档详细介绍了在使用 AJAX 上传文件时,如何正确地将额外数据(如ID)传递到服务器端。重点讲解了 FormData 对象的使用,以及如何避免常见的错误配置,并提供代码示例。同时,本文也强调了服务器端代码安全性,特别是防止 SQL 注入攻击的重要性,并给出了相关的安全建议和资源链接。 通过 Fo…

    2025年12月11日
    000
  • 深入理解 WooCommerce 预订商品程序化加入购物车失败的问题

    本文探讨了在 WooCommerce 中通过代码程序化添加预订商品至购物车的复杂性与常见失败模式。尽管能够成功创建预订数据记录,但直接调用购物车相关函数或模拟用户行为均遭遇瓶颈,揭示了 WooCommerce 预订系统与购物车集成机制的深层挑战,并分析了现有尝试为何未能提供稳定可靠的解决方案。 在开…

    2025年12月11日
    000
  • PHP如何防止SQL注入_PHP防范SQL注入攻击的核心策略

    防范SQL注入的核心是预处理语句,它通过将SQL逻辑与数据分离,确保用户输入始终作为数据处理;结合参数绑定,使用PDO或MySQLi扩展可有效阻止恶意SQL执行,从根本上避免注入风险。 PHP防范SQL注入的核心策略,毫无疑问是采用预处理语句(Prepared Statements)配合参数绑定(P…

    2025年12月11日
    000
  • PHP姓名格式化:提取首名与姓氏首字母的实用指南

    本文旨在提供一个PHP解决方案,用于将完整姓名格式化为“首名. 姓氏首字母.”的形式,例如将“Mike Jones”转换为“Mike. J.”。文章将详细解释如何利用explode、reset、end和mb_substr等函数,高效且准确地实现这一需求,并讨论多部分姓名及单名情况的处理策略。 理解姓…

    2025年12月11日
    000
  • 解决WooCommerce预订产品程序化加入购物车失败的问题

    本文探讨了在WooCommerce中通过编程方式将预订产品添加到购物车时遇到的挑战。尽管可以成功创建预订记录,但直接使用API方法将预订添加到购物车常常失败。文章分析了尝试的API调用及其参数,并提出了一种模拟前端表单提交的“变通方案”,但指出该方案存在会话依赖性,并非一个稳定可靠的编程解决方案,最…

    2025年12月11日
    000
  • 精确控制JavaScript定时任务:实现整点弹窗与桌面通知

    本文详细阐述了如何利用JavaScript精确控制定时任务,以实现在指定时间(例如每小时的整点)触发弹窗或发送桌面通知。通过结合短间隔定时器、日期对象判断和防重复触发机制,解决了传统setInterval无法实现整点触发的问题,并提供了完整的代码示例及桌面通知的实现方法。 1. 理解传统定时器的局限…

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信