在Pug模板中正确使用和JavaScript访问HTML data-* 属性

在Pug模板中正确使用和JavaScript访问HTML data-* 属性

本教程详细阐述了在Pug模板中定义并从JavaScript中正确访问HTML data-* 属性的关键。核心在于理解HTML data-* 属性必须以 data- 前缀命名,且在JavaScript中通过 HTMLElement.dataset 访问时,kebab-case 会自动转换为 camelCase。文章通过代码示例,指导开发者避免常见错误,确保前后端数据传递的顺畅性。

引言:理解 data-* 属性的作用

在web开发中,我们经常需要在html元素上存储一些不属于标准属性的自定义数据,以便javascript脚本能够读取和操作。html5引入的 data-* 全局属性正是为此目的而生。它们提供了一种标准的方式来存储私有数据,这些数据对页面内容的呈现没有直接影响,但可以被javascript轻松访问。

例如,一个按钮可能需要关联一个ID或一个特定的操作类型,这些信息可以通过 data-* 属性附加到按钮元素上,然后在用户点击时被JavaScript获取并处理。

问题解析:错误的 data-* 属性命名

在Pug(或任何HTML模板引擎)中定义 data-* 属性时,一个常见的错误是未能遵循其严格的命名规范。根据HTML标准,所有自定义数据属性都必须以 data- 前缀开头。

考虑以下Pug代码片段:

button.sbt-enroll(subject-data-slug=`${subject[0].slug}`) enroll

这里的属性名 subject-data-slug 虽然包含了 data 关键字,但它并没有以 data- 作为完整的前缀。这意味着浏览器不会将其识别为一个标准的 data-* 属性。当JavaScript尝试通过 HTMLElement.dataset API来访问这个属性时,它将无法找到预期的值,因为 dataset API只处理符合 data- 命名规范的属性。

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

例如,如果一个属性是 my-data-id=”123″,那么在JavaScript中可以通过 element.dataset.myId 来访问。但如果属性是 custom-id=”123″,则 dataset 将无法直接访问它。在上述Pug示例中,subject-data-slug 实际上被视为一个普通的自定义属性,而不是 data-* 属性家族的一员。

解决方案:遵循 data-* 规范与 dataset 访问规则

要正确地在Pug模板中定义 data-* 属性并在JavaScript中访问它们,需要遵循以下两个关键规则:

HTML属性命名: 属性名必须以 data- 开头,后面跟着一个或多个小写字母、数字、连字符(-)、点(.)、冒号(:)或下划线(_)。通常推荐使用 kebab-case(短横线连接)来命名 data-* 属性,例如 data-subject-slug。

JavaScript访问: 当通过 HTMLElement.dataset 属性访问这些数据时,JavaScript会自动将 kebab-case 命名的属性转换为 camelCase(驼峰命名法)。例如,data-subject-slug 将被转换为 subjectSlug。

Pug模板中的正确定义

将原始的Pug代码修改为符合 data-* 规范:

button.sbt-enroll(data-subject-slug=`${subject[0].slug}`) enroll

这里,我们将属性名从 subject-data-slug 修改为 data-subject-slug,使其完全符合HTML data-* 属性的命名规范。

JavaScript中的正确访问

相应地,在JavaScript中访问这个属性时,需要使用其 camelCase 形式:

let subjectBtn = document.querySelector(".sbt-enroll");if (subjectBtn) {  subjectBtn.addEventListener("click", (e) => {    e.preventDefault();    // 从 e.target.dataset 中解构出 subjectSlug    // data-subject-slug 在 JS 中对应 subjectSlug    const { subjectSlug } = e.target.dataset;    applySubject(subjectSlug);  });}// 示例:假设 applySubject 函数存在function applySubject(slug) {  console.log(`Applying subject with slug: ${slug}`);  // 可以在这里执行 AJAX 请求或页面跳转等操作}

通过以上修改,当点击按钮时,e.target.dataset 将能够正确识别并包含 subjectSlug 属性,从而允许 applySubject 函数接收到正确的数据。

完整代码示例

为了更好地理解,以下是Pug模板和JavaScript代码的关键部分的整合示例:

Pug 模板 (index.pug)

doctype htmlhtml  head    // ... 其他头部内容 ...    title= subject[0].name    style      include ../public/style.css  body    section.courses-background      // ... 导航和其他元素 ...      .text-box        h1= subject[0].name        p= subject[0].summary    // subjects    section.course      p= subject[0].description      .subject        // 修正后的 data-* 属性        button.sbt-enroll(data-subject-slug=`${subject[0].slug}`) enroll  // 确保脚本在 DOM 元素加载后执行  script(src='/js/bundle.js')

JavaScript 文件 (bundle.js 或 index.js)

// 获取按钮元素let subjectBtn = document.querySelector(".sbt-enroll");// 确保按钮存在,避免空引用错误if (subjectBtn) {  // 添加点击事件监听器  subjectBtn.addEventListener("click", (e) => {    e.preventDefault(); // 阻止默认行为,如表单提交    // 从事件目标(被点击的按钮)的 dataset 中获取数据    // data-subject-slug 在 JavaScript 中被访问为 subjectSlug    const { subjectSlug } = e.target.dataset;    // 调用处理函数,并传入获取到的 slug    applySubject(subjectSlug);  });}// 定义 applySubject 函数function applySubject(slug) {  console.log(`执行报名操作,科目 slug 为: ${slug}`);  // 在这里可以添加实际的业务逻辑,例如:  // - 发送 AJAX 请求到后端 API 进行报名  // - 页面重定向到报名确认页  // - 显示一个确认消息}

注意事项与最佳实践

命名规范的严格性: 始终牢记 data-* 属性必须以 data- 开头。任何不符合这个前缀的属性都不会被 HTMLElement.dataset API识别。驼峰命名转换: 从 kebab-case 到 camelCase 的自动转换是 dataset API 的核心特性。理解这一点对于在JavaScript中正确访问属性至关重要。脚本加载时机: 确保你的JavaScript代码在DOM元素完全加载并可用之后再执行。将 标签放在

以上就是在Pug模板中正确使用和JavaScript访问HTML data-* 属性的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 07:34:50
下一篇 2025年12月20日 07:35:05

相关推荐

  • js怎样获取当前时间戳

    获取当前时间戳最推荐的方式是使用 date.now()。1. 使用 date.now() 可直接获取毫秒级时间戳,如 const timestampms = date.now(); 2. 若需秒级时间戳,可将毫秒级时间戳除以1000并向下取整,如 const timestampsec = math.…

    2025年12月20日 好文分享
    000
  • javascript闭包怎么在回调中传递参数

    javascript闭包在回调中传递参数的核心是利用其能“记住”创建时外部作用域变量的特性;2. 通过创建一个外部函数接收参数并返回一个内部函数(闭包),使该内部函数在异步或延迟执行时仍可访问外部函数的参数;3. 例如在循环中为按钮绑定点击事件时,使用createclickhandler(i)为每个…

    2025年12月20日 好文分享
    000
  • js如何实现原型链的扁平化

    原型链扁平化是为了提升性能,通过减少原型链查找层级来加快属性和方法访问速度。1. 直接复制属性和方法:简单但无法同步父类原型变化;2. 使用object.assign():语法简洁,仍存在同步问题且复制引用可能引发意外共享;3. 寄生组合继承中直接赋值原型:高效但导致子类与父类共享原型,修改一方会影…

    2025年12月20日 好文分享
    000
  • javascript如何实现数组差异对比

    javascript实现数组差异对比的核心答案是:使用filter结合includes可实现基础差异比较,但性能较低;推荐使用set提升性能,对重复元素需用计数对象处理,对对象数组则需自定义比较函数。1. 基础方法:filter + includes,代码简洁但时间复杂度为o(n²),适用于小数组;…

    2025年12月20日 好文分享
    000
  • 多维数组索引存在性检查:JavaScript 中的安全访问

    本文旨在解决 JavaScript 中多维数组索引访问时可能遇到的 “Uncaught TypeError: Cannot read properties of null (reading .)” 错误。通过介绍可选链操作符,提供了一种优雅且安全的方式来检查多维数组中是否存在…

    2025年12月20日
    000
  • JavaScript多维数组安全访问:掌握可选链操作符

    在JavaScript中,当尝试访问多维数组或嵌套对象中可能不存在的属性时,常常会遇到“Uncaught TypeError: Cannot read properties of null (reading .)”错误。本文将深入探讨这一常见问题,并重点介绍ECMAScript 2020引入的可选链…

    好文分享 2025年12月20日
    000
  • JavaScript 中安全访问多维数组:利用可选链操作符避免空指针错误

    本文旨在解决 JavaScript 中访问多维数组时可能遇到的空指针错误。通过引入可选链操作符,开发者可以安全地访问深层嵌套的数组元素,避免因中间层级不存在而导致的程序崩溃。本文将详细介绍可选链操作符的用法,并提供示例代码,帮助读者掌握在 JavaScript 中安全访问多维数组的技巧。 在 Jav…

    2025年12月20日
    000
  • 多维数组中如何安全地检查索引是否存在?

    在 JavaScript 中处理多维数组时,经常会遇到需要访问深层嵌套的属性的情况。然而,如果某些索引不存在,直接访问可能会导致 “TypeError: Cannot read properties of null (reading …)” 错误,使程序崩溃。为了…

    2025年12月20日
    000
  • Next.js 13 静态站点生成:缓存控制与 index.txt 问题解决

    本文旨在解决 Next.js 13 静态站点生成中,浏览器缓存 index.txt 文件导致更新无法及时生效的问题。通过分析问题原因,提供了一种修改 generateStaticParams 配置的解决方案,以确保每次构建后,浏览器能够获取最新的静态资源,从而保证用户体验。 在 Next.js 13…

    2025年12月20日
    000
  • ReCAPTCHA V3与V2混合部署策略:为低分用户提供挑战机制

    ReCAPTCHA V3以其无感验证提升用户体验,但在面对低分合法用户时,直接阻断并非理想方案。本文探讨了ReCAPTCHA V3在低分情况下如何提供挑战机制的问题。通过结合ReCAPTCHA V2,我们能实现初次无感验证,并为可疑但合法的用户提供二次挑战,从而在保障用户体验的同时,有效抵御自动化流…

    2025年12月20日
    000
  • ReCAPTCHA V3低分处理策略:结合V2挑战提升用户体验与安全性

    本文探讨了ReCAPTCHA V3在识别低分但合法用户时面临的挑战,并提出一种混合解决方案。通过在后端评估V3得分,当分数低于预设阈值时,前端动态呈现ReCAPTCHA V2挑战,从而在保持大多数用户无感体验的同时,为潜在的合法用户提供验证机会,有效平衡了安全性与用户体验。 ReCAPTCHA V3…

    2025年12月20日
    000
  • ReCAPTCHA V3低分处理策略:结合V3与V2实现智能风险控制与用户验证

    本文旨在解决ReCAPTCHA V3在低分情况下无法直接触发验证码挑战的问题。我们将探讨如何通过巧妙地结合ReCAPTCHA V3的无感评分机制与ReCAPTCHA V2的交互式挑战,实现一套既能有效阻挡机器人流量,又能最大限度减少对合法用户干扰的智能验证系统。文章将详细阐述其实现原理、前端与后端集…

    2025年12月20日
    000
  • ReCAPTCHA V3与V2混合部署:实现智能验证与挑战回退机制

    本文探讨了如何结合使用ReCAPTCHA V3的无感验证和ReCAPTCHA V2的交互式挑战,以解决V3低分用户误判问题。通过在后端评估V3得分,当分数低于预设阈值时,触发V2挑战作为回退机制,从而在提供流畅用户体验的同时,有效拦截机器人流量并确保合法用户访问。 ReCAPTCHA V3的局限性与…

    2025年12月20日
    000
  • javascript闭包怎么在IIFE中应用

    iife与闭包结合的核心是创建私有作用域并封装数据,通过闭包访问iife内部变量实现模块化;2. 这种模式避免全局污染、实现数据封装和明确依赖,曾是javascript模块化的标准方案;3. 常见陷阱包括循环中var变量共享导致的闭包问题,可用iife为每次循环创建独立作用域解决;4. 需注意闭包可…

    2025年12月20日 好文分享
    000
  • js怎么检查数组是否包含某元素

    includes() 方法最简洁,返回布尔值,支持 nan 检查,但不兼容旧浏览器;2. indexof() 通过返回索引检查存在性,使用严格相等,不支持 nan;3. find()/findindex() 支持复杂条件和对象比较,但性能较低;4. 对于对象需自定义比较函数;5. 第三方库如 lod…

    2025年12月20日 好文分享
    000
  • js怎样检测用户在线状态

    js无法100%准确检测用户在线状态,最可靠的方法是结合心跳机制与服务器端判断。1. 通过setinterval定期发送心跳请求,连续多次失败后判定为离线;2. 利用beforeunload事件配合navigator.sendbeacon通知服务器用户即将关闭页面;3. 服务器综合心跳、最后活动时间…

    2025年12月20日 好文分享
    000
  • 实现定时器执行指定次数后停止

    本文介绍了如何使用 JavaScript 的 setInterval 函数实现定时任务,并控制其执行次数。通过引入计数器和条件判断,可以在定时器执行特定次数后自动停止,避免无限循环。本文提供了详细的代码示例和解释,帮助开发者理解和应用该技术。 在 Web 开发中,setInterval 函数是一个非…

    2025年12月20日
    000
  • Swiper.js:同时显示进度条和分页数字的自定义方法

    本文介绍了如何在 Swiper.js 轮播图中同时显示进度条和分页数字。通过自定义分页渲染函数 renderCustom,可以灵活地组合进度条和分页数字,并自定义它们的样式,从而实现更丰富的用户体验。本文提供了详细的代码示例和步骤说明,帮助开发者轻松实现这一功能。 在 Swiper.js 中,默认情…

    2025年12月20日
    000
  • Swiper.js:同时显示进度条和分页数字的终极指南

    本文旨在帮助开发者在使用 Swiper.js 轮播图组件时,同时展示进度条和分页数字。通过自定义分页渲染函数,我们可以将进度条和分页数字整合到一起,提供更丰富的用户体验。本文将提供详细的代码示例和步骤,助你轻松实现这一功能。 在使用 Swiper.js 创建轮播图时,我们经常需要展示分页信息,以便用…

    2025年12月20日
    000
  • Swiper.js:同时显示进度条和分页数字的定制化方案

    本文旨在提供一种在 Swiper.js 中同时显示进度条和分页数字的解决方案。通过自定义分页渲染函数,将进度条和分页数字的 HTML 结构组合在一起,并利用 CSS 进行样式控制,从而实现更丰富的用户体验。本文将提供详细的代码示例和步骤说明,帮助开发者轻松实现这一功能。 在 Swiper.js 中,…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信