0

0

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

聖光之護

聖光之護

发布时间:2025-08-02 10:46:13

|

932人浏览过

|

来源于php中文网

原创

在 pug 模板中正确使用和访问 html data-* 属性

本文详细介绍了在 Pug 模板中定义和在 JavaScript 中访问 HTML data-* 属性的正确方法。通过实例代码,解释了 data- 前缀的重要性以及 JavaScript dataset API 如何将连字符命名转换为驼峰命名,帮助开发者有效解决从模板传递数据到脚本的问题,提升前端交互性。

引言:前端数据传递与 data-* 属性

在现代前端开发中,我们经常需要将 HTML 元素上的特定数据传递给 JavaScript 进行处理,例如按钮点击时获取其关联的 ID 或配置信息。HTML5 引入的 data-* 全局属性提供了一种标准且语义化的方式来存储自定义数据。这些属性允许开发者在不使用非标准属性、额外 DOM 属性或 Node.js 变量的情况下,将额外信息附加到标准 HTML 标签上。

然而,在使用像 Pug 这样的模板引擎时,开发者有时会遇到在模板中定义了 data-* 属性,但在 JavaScript 中无法正确访问的问题。这通常是由于对 data-* 属性的命名规范和 JavaScript dataset API 的工作原理理解不足导致的。

理解 HTML data-* 属性与 dataset API

data-* 属性的命名规则非常明确:它们必须以 data- 作为前缀,后面可以跟任何自定义的名称(允许包含连字符 -)。例如,data-id、data-user-name、data-product-slug 都是有效的 data-* 属性。

在 JavaScript 中,可以通过 HTMLElement 接口的 dataset 属性来访问这些自定义数据。dataset 属性返回一个 DOMStringMap 对象,其中包含了所有 data-* 属性的键值对。需要注意的是,当通过 dataset 访问这些属性时,JavaScript 会自动将连字符命名的 data-* 属性转换为驼峰命名(camelCase)。

立即学习前端免费学习笔记(深入)”;

例如:

  • data-id 会在 dataset 中映射为 dataset.id。
  • data-user-name 会映射为 dataset.userName。
  • data-product-slug 会映射为 dataset.productSlug。

在 Pug 模板中定义 data-* 属性

在 Pug(以前称为 Jade)模板中定义 HTML 属性非常简洁。对于 data-* 属性,关键在于严格遵循 data- 前缀的命名规范。

错误示例(常见误区):

// 错误的命名方式,data- 前缀没有放在最前面
button.sbt-enroll(subject-data-slug=`${subject[0].slug}`) enroll

在这个例子中,subject-data-slug 并不是一个标准的 data-* 属性,因为它没有以 data- 开头。尽管它看起来像一个数据属性,但浏览器并不会将其解析到 dataset 对象中。

飞书妙记
飞书妙记

飞书智能会议纪要和快捷语音识别转文字

下载

正确示例:

要确保属性被识别为 data-* 属性并可通过 dataset 访问,必须以 data- 作为属性名的开头。

// 正确的命名方式,以 data- 开头
button.sbt-enroll(data-subject-slug=`${subject[0].slug}`) enroll

这里,data-subject-slug 是一个标准的 data-* 属性。Pug 会将其正确渲染为

在 JavaScript 中访问 dataset 属性

一旦在 Pug 模板中正确定义了 data-* 属性,就可以在 JavaScript 中使用 HTMLElement.dataset API 轻松访问它们。记住,连字符命名会转换为驼峰命名。

JavaScript 访问示例:

假设我们有以下 Pug 模板:

// pug/index.pug
doctype html
html
  head
    title My Subject Page
    style
      include ../public/style.css
  body
    section.course
      .subject
        // 注意这里使用了 data-subject-slug
        button.sbt-enroll(data-subject-slug=`${subject[0].slug}`) enroll

    script(src='/js/bundle.js')

以及对应的 JavaScript 文件 (public/js/bundle.js):

// public/js/bundle.js

// 假设 subject[0].slug 在服务器端被渲染为 "web-development"
// 那么按钮的 HTML 将是 

let subjectBtn = document.querySelector(".sbt-enroll");

if (subjectBtn) {
  subjectBtn.addEventListener("click", (e) => {
    e.preventDefault();

    // 从 e.target.dataset 中获取数据
    // data-subject-slug 会被转换为 subjectSlug
    const { subjectSlug } = e.target.dataset;

    console.log("Subject Slug:", subjectSlug); // 输出: Subject Slug: web-development

    // 调用处理函数
    applySubject(subjectSlug);
  });
}

function applySubject(slug) {
  // 模拟一个异步操作,例如发送请求到后端
  console.log(`Applying for subject: ${slug}`);
  // 实际应用中可能包含 AJAX 请求、页面跳转等
  alert(`成功申请课程:${slug}`);
}

// 确保在 DOM 完全加载后执行脚本
// 如果 script 标签放在 body 底部,通常不需要DOMContentLoaded
// 但如果 script 标签在 head 中,则需要
// document.addEventListener('DOMContentLoaded', () => {
//   // ... 上面的代码 ...
// });

在这个 JavaScript 示例中,e.target.dataset 返回一个包含所有 data-* 属性的对象。由于 Pug 中定义的属性是 data-subject-slug,因此在 JavaScript 中,它被转换为驼峰命名的 subjectSlug,我们可以通过解构赋值 const { subjectSlug } = e.target.dataset; 来直接获取其值。

注意事项与总结

  1. data- 前缀强制性: 任何自定义数据属性都必须以 data- 开头。这是 HTML 规范的要求,也是 dataset API 识别它们的唯一方式。
  2. 驼峰命名转换: 在 JavaScript 中访问 dataset 时,所有 data- 后面的连字符命名都会被转换为驼峰命名。例如,data-my-custom-attribute 对应 dataset.myCustomAttribute。
  3. 脚本加载时机: 确保你的 JavaScript 代码在 DOM 元素(包括你的按钮)加载并可用之后执行。最常见的做法是将

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

418

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

511

2023.10.23

HTML与HTML5的区别
HTML与HTML5的区别

HTML与HTML5的区别:1、html5支持矢量图形,html本身不支持;2、html5中可临时存储数据,html不行;3、html5新增了许多控件;4、html本身不支持音频和视频,html5支持;5、html无法处理不准确的语法,html5能够处理等等。想了解更多HTML与HTML5的相关内容,可以阅读本专题下面的文章。

435

2024.03.06

html5从入门到精通汇总
html5从入门到精通汇总

想系统掌握HTML5开发?本合集精选全网优质学习资源,涵盖免费教程、实战项目、视频课程与权威电子书,从基础语法到高级特性(Canvas、本地存储、响应式布局等)一应俱全,适合零基础小白到进阶开发者,助你高效入门并精通HTML5前端开发。

69

2025.12.30

html5新老标签汇总
html5新老标签汇总

HTML5在2026年持续优化网页语义化与交互体验,不仅引入了如<header>、<nav>、<article>、<section>、<aside>、<footer>等结构化标签,还新增了<video>、<audio>、<canvas>、<figure>、<time>、<mark>等增强多媒体与

104

2025.12.30

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

1

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 24.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号