0

0

JavaScript如何操作样式_CSS与JavaScript如何交互

夢幻星辰

夢幻星辰

发布时间:2026-01-06 20:50:03

|

381人浏览过

|

来源于php中文网

原创

直接修改 element.style 仅影响行内样式,优先级高但范围窄;应使用 classList 管理类名、getComputedStyle() 获取最终样式、动态样式推荐插入 <style> 标签或 CSS 变量。

javascript如何操作样式_css与javascript如何交互

直接改 element.style 只影响行内样式,且优先级高但覆盖范围窄

这是最常用也最容易误解的方式。给元素设置 style 属性,本质是操作 DOM 元素的 style 对象,它只读写 HTML 中的 style 行内属性(如 <div style="color: red">),不会触碰 CSS 类、外部样式表或 <style> 块里的规则。

常见错误:以为 el.style.color = 'blue' 能覆盖掉某个 CSS 类里定义的 color —— 实际上可以,因为行内样式优先级高于类选择器;但反过来,如果那个类用了 !important,那这行 JS 就失效了。

注意点:

  • style 属性名用驼峰(backgroundColor),不是短横线(background-color
  • 单位必须显式写出(el.style.width = '200px'),数值型赋值会自动转成像素(el.style.width = 200"200px"),但仅限于 width/height 等少数属性,不通用
  • 批量设置建议用 Object.assign(el.style, { opacity: 0.5, transform: 'scale(0.9)' }),比逐行写更安全

切换类名用 classList,别再用 className 拼字符串

element.className 是个字符串,手动增删类容易出错(比如多空格、重复添加、误删其他类)。现代浏览器都支持 element.classList,它是个类数组对象,提供语义化方法:

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

el.classList.add('active', 'fade-in');
el.classList.remove('disabled');
el.classList.toggle('hidden');
el.classList.contains('error'); // true / false
el.classList.replace('old', 'new');

特别适合状态控制:按钮加载中、菜单展开、表单校验失败等场景。和 CSS 配合时,所有样式逻辑留在 CSS 文件里,JS 只管“是什么状态”,不操心“长什么样”。

兼容性提醒:classList 在 IE10+ 支持,IE9 及以下需用 polyfill 或退回到 className 字符串操作(不推荐)。

读取最终计算样式要用 getComputedStyle(),不是 element.style

element.style 只返回行内样式,而你真正想知道的往往是“这个元素现在实际显示成什么样”——包括继承的、层叠后生效的、甚至浏览器默认样式。这时得用:

AITDK
AITDK

免费AI SEO工具,SEO的AI生成器

下载
const computed = getComputedStyle(el);
console.log(computed.color);        // "rgb(255, 0, 0)"
console.log(computed.fontSize);      // "16px"
console.log(computed.getPropertyValue('border-top-width')); // "1px"

关键细节:

  • 返回的是只读的 CSSStyleDeclaration,不能直接赋值
  • 所有值都是绝对单位(pxrgb()),没有相对单位(em%rem)原始值
  • 伪元素也能查,比如 getComputedStyle(el, '::before')
  • 频繁调用可能触发重排(reflow),如需多次读取,先缓存结果

动态加 CSS 规则?用 document.styleSheets 或插入 <style>

运行时生成样式规则(比如主题色切换、暗黑模式、图表配色),有两种主流方式:

方式一:插入新 <style> 标签(简单直接,推荐)

const style = document.createElement('style');
style.textContent = `
  .theme-dark .card { background: #222; color: #eee; }
  .theme-dark button:hover { border-color: #444; }
`;
document.head.appendChild(style);

方式二:往已有样式表追加规则(更精细,但有跨域限制)

const sheet = document.styleSheets[0];
sheet.insertRule('.highlight { animation: pulse 2s infinite; }', sheet.cssRules.length);

注意点:

  • insertRule 时,IE 需用 addRule(已废弃),现代项目可忽略
  • 动态样式若依赖 JS 计算(如颜色渐变),建议生成后存在 <style id="dynamic-theme"> 里,后续替换内容比反复删增标签更高效
  • 服务端渲染(SSR)场景下,动态插入的 <style> 可能导致水合(hydration)不一致,需同步服务端输出

最常被忽略的一点:CSS 变量(custom properties)其实是 JS 和 CSS 之间最轻量的桥梁——直接改 document.documentElement.style.setProperty('--primary-color', '#3b82f6'),所有用到该变量的地方实时响应,无需操作 DOM 或样式表。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

651

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1204

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

193

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

131

2025.08.07

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.8万人学习

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

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