0

0

如何为多个按钮元素动态切换字体样式

心靈之曲

心靈之曲

发布时间:2026-03-03 10:27:02

|

967人浏览过

|

来源于php中文网

原创

如何为多个按钮元素动态切换字体样式

本文详解如何使用原生 javascript 为页面中所有按钮元素统一、独立地切换自定义字体(如 google fonts),修复常见 classlist.toggle 失效问题,并提供健壮、可复用的实现方案。

本文详解如何使用原生 javascript 为页面中所有按钮元素统一、独立地切换自定义字体(如 google fonts),修复常见 classlist.toggle 失效问题,并提供健壮、可复用的实现方案。

在网页开发中,常需通过点击操作动态切换元素的字体样式——例如将普通按钮一键切换为醒目无衬线字体(如 Google Fonts 中的 Anton)。但初学者易陷入逻辑误区:误用全局状态判断、混淆 DOM 引用比较,或忽略 CSS 字体声明语法细节,导致 classList.toggle() 表面调用却无视觉变化。

✅ 正确实现原理

核心在于每个按钮应独立响应点击事件,并仅操作自身样式类,而非遍历全部按钮统一处理。原代码中 if (toggleFontFamily[i] == toggleFontFamily[0]) 的写法是错误的:DOM 元素对象无法用 == 进行有意义的相等性比较(始终返回 false),导致逻辑失效;同时,onclick="changeFont()" 触发的是同一函数,却试图在函数内手动区分按钮索引,既冗余又脆弱。

MyMap AI
MyMap AI

使用AI将想法转化为图表

下载

正确做法是:

  1. 使用 querySelectorAll('button') 获取所有按钮节点集合;
  2. 遍历集合,为每个按钮单独绑定 click 事件监听器
  3. 在事件回调中使用 this 指向当前被点击的按钮,调用 this.classList.toggle('invisible') —— 简洁、精准、无副作用。

? 完整可运行代码示例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Button Font Toggle</title>
    <!-- 预连接并加载 Google Fonts -->
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Anton&display=swap" rel="stylesheet">

    <style>
        /* 基础字体:系统默认 */
        button {
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
            padding: 8px 16px;
            margin: 4px;
            border: 1px solid #ccc;
            border-radius: 4px;
            cursor: pointer;
        }

        /* 切换后应用的字体样式 */
        .invisible {
            font-family: 'Anton', sans-serif; /* 注意:font-family 值之间必须用英文逗号分隔 */
            letter-spacing: 1px;
            font-weight: 400;
        }
    </style>
</head>
<body>
    <button>Abraham Abah</button>
    <button>Work</button>
    <button>Lab</button>

    <script>
        // 获取所有 button 元素
        const buttons = document.querySelectorAll('button');

        // 为每个按钮绑定独立点击事件
        buttons.forEach(button => {
            button.addEventListener('click', function() {
                this.classList.toggle('invisible');
            });
        });
    </script>
</body>
</html>

⚠ 关键注意事项

  • CSS 字体声明语法:font-family: 'Anton', sans-serif; 中,字体名与备选字体之间必须使用英文逗号 , 分隔,不可用空格或中文标点。原代码中 'Anton' 'sans-serif' 缺少逗号,会导致字体加载失败。
  • 事件委托更优场景:若按钮是动态添加的(如通过 AJAX 插入),建议改用事件委托(监听父容器),避免重复绑定:
    document.body.addEventListener('click', function(e) {
        if (e.target.tagName === 'BUTTON') {
            e.target.classList.toggle('invisible');
        }
    });
  • 性能与语义:forEach() 比传统 for 循环更简洁安全;避免使用 onclick 内联事件,遵循 HTML 与 JS 分离原则。
  • 字体加载保障:Google Fonts 加载存在延迟,可监听 document.fonts.load() 或添加 font-display: swap(已在 &display=swap 参数中启用),确保文本不长时间空白。

✅ 总结

实现按钮字体切换,本质是「事件驱动 + 类名控制」的组合:为每个目标元素独立绑定事件,利用 this 精准操作自身样式类。摒弃基于索引的手动分支判断,既提升代码可读性与可维护性,也从根本上规避 DOM 对象比较陷阱。配合规范的 CSS 字体语法与现代 API(forEach, addEventListener),即可构建稳定、专业、符合最佳实践的交互效果。

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

166

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

124

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

252

2024.09.24

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

839

2023.08.22

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

202

2025.12.04

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

514

2023.07.28

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

0

2026.03.03

热门下载

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

精品课程

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

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