一起看看JavaScript与CSS和Sass如何进行交互

一起看看JavaScript与CSS和Sass如何进行交互

JavaScript 和 CSS 已经并存超过了 20 年。但是在它们之间共享数据非常困难。当然也有大量的尝试。但是我所想到的是一些简单而直观的内容——不涉及结构更改,而是使用 CSS 自定义属性甚至 Sass 变量。

CSS 自定义属性和 JavaScript

自定义属性在这里应该不会令人感到惊讶。自浏览器提供支持以来??,他们一直在做的一件事就是与 JavaScript 协同工作以设置和操作值。

不过具体来说,我们可以通过几种方式使 JavaScript 与自定义属性一起工作。可以使用 setProperty 设置自定义属性的值:

document.documentElement.style.setProperty("--padding", 124 + "px"); // 124px

登录后复制

我们还可以用 JavaScript 中的 设置和操作值 来检索 CSS 变量。其背后的逻辑非常简单:自定义属性是样式的一部分,因此它们是计算样式的一部分。

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

getComputedStyle(document.documentElement).getPropertyValue('--padding') // 124px

登录后复制

与 getPropertyValue 一样。这样我们就可以从 HTML 标记的内联样式中获得自定义属性值。

document.documentElement.style.getPropertyValue("--padding'"); // 124px

登录后复制

请注意,自定义属性是有作用域的。这意味着我们需要从特定元素获取计算样式。正如我们之前在:root 中定义变量一样,我们将它们放在 HTML 元素上。

Sass 变量和 JavaScript

Sass 是一种预处理语言,这意味着它在成为网站的一部分之前就已经变成了 CSS。所以无法用与 CSS 自定义属性相同的方式从 JavaScript 访问它们(可以在 DOM 中以计算样式访问它们)。

我们需要通过修改自己的构建过程来改变这一点。我怀疑在大多数情况下并不需要做太多,因为装载程序通常已经是构建过程的一部分。但是如果你的项目并非如此,则我们需要三个模块,这些模块能够导入和翻译 Sass 模块。

在 Webpack 配置中看上去是这样:

css$/, use: [“style-loader”, “css-loader”, “sass-loader”] }, // … ] }};” title=”” data-original-title=”复制”>

module.exports = { // ... module: {  rules: [   {    test: /.scss$/,    use: ["style-loader", "css-loader", "sass-loader"]   },   // ...  ] }};

登录后复制

为了使 Sass(或者在这种情况下,具体来说是 SCSS)变量可用于 JavaScript,我们需要 “export” 它们。

// variables.scss$primary-color: #fe4e5e;$background-color: #fefefe;$padding: 124px;:export {  primaryColor: $primary-color;  backgroundColor: $background-color;  padding: $padding;}

登录后复制

:export 块是 webpack 用来导入变量的。这种方法的好处是,我们可以用 camelCase 语法重命名变量,然后选择要公开的内容。

然后,把 Sass 文件(variables.scss)导入 JavaScript,从而可以访问文件中定义的变量。

import variables from './variables.scss';/* {  primaryColor: "#fe4e5e"  backgroundColor: "#fefefe"  padding: "124px" }*/document.getElementById("app").style.padding = variables.padding;

登录后复制

值得一提的是对 :export 语法的一些限制:

它必须在顶层,但可以在文件中的任何位置。如果文件中有多个,则将 key 和 value 组合在一起一并导出。如果特定的 exportedKey 被复制,则最后一个(按源顺序)优先。exportedValue 可以含有在 CSS 声明值中任何有效的字符(包括空格)。exportedValue 不需要被引用,因为它已经被当作文本字符串了。

有很多方法可以方便地访问 JavaScript 中的 Sass 变量。我倾向于使用这种共享断点的方法。下面是我的breakpoints.scs 文件,后来我将其导入 JavaScript 中,这样我可以用 matchMedia()方法得到一致的断点。

// Sass variables that define breakpoint values$breakpoints: (  mobile: 375px,  tablet: 768px,  // etc.);// Sass variables for writing out media queries$media: (  mobile: '(max-width: #{map-get($breakpoints, mobile)})',  tablet: '(max-width: #{map-get($breakpoints, tablet)})',  // etc.);// The export module that makes Sass variables accessible in JavaScript:export {  breakpointMobile: unquote(map-get($media, mobile));  breakpointTablet: unquote(map-get($media, tablet));  // etc.}

登录后复制

动画是另一个用例。动画的持续时间通常存储在 CSS 中,但是需要 JavaScript 的帮助才能完成更复杂的动画。

// animation.scss$global-animation-duration: 300ms;$global-animation-easing: ease-in-out;:export {  animationDuration: strip-unit($global-animation-duration);  animationEasing: $global-animation-easing;}

登录后复制

请注意,在导出变量时,我用了自定义 设置和操作值 函数。这使我可以轻松地在 JavaScript 中解析内容。

// main.jsdocument.getElementById('image').animate([  { transform: 'scale(1)', opacity: 1, offset: 0 },  { transform: 'scale(.6)', opacity: .6, offset: 1 }], {  duration: Number(variables.animationDuration),  easing: variables.animationEasing,});

登录后复制

这样就能轻松地在CSS、Sass 和 JavaScript 之间交换数据。共享这样的变量使代码简单而不啰嗦。

当然还有多种方法可以实现相同的目的。 Les James 设置和操作值,该方法允许 Sass 和 JavaScript 通过 JSON 进行交互。我对此可能存有偏见,但是我发现在这里介绍的方法是最简单、最直观的。无需对你已经在使用和正在编写的 CSS 和 JavaScript 进行疯狂的修改。

英文原文地址:https://css-tricks.com/getting-javascript-to-talk-to-css-and-sass/作者:Marko Ilic

更多编程相关知识,请访问:设置和操作值!!

以上就是一起看看JavaScript与CSS和Sass如何进行交互的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2717584.html

(0)
上一篇 2025年3月7日 22:06:32
下一篇 2025年3月7日 10:04:08

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 深入浅析JavaScript中的对象字面量

    本篇文章带大家了解一下javascript中的对象字面量,分析一下为什么对象字面量很酷。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 在 ECMAScript 2015 之前,Javascript 中的对象字面量(又叫做…

    2025年3月7日
    200
  • 值得收藏的20个前端开发ICON图标库

    本篇文章给大家分享20个icon图标库(值得收藏),让你的网站跟美观、有可读性。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 在应用界面中图标的存在,会给用户一个良好第一印象,这个挺重要的。但是从零开始开发图标需要大量的…

    2025年3月7日 编程技术
    200
  • javascript如何换行

    javascript进行换行的方法:首先在hmtl中添加一个按钮;然后在js中添加一个消息提示方法,代码为【var tips=”我是”+””+”小编”;alert(ti…

    2025年3月7日
    200
  • js如何判断字符串是否为空

    js判断字符串是否为空的方法:1、判断字符串是否为空,代码为【if (string.length == 0)】;2、判断字符串是否为“空”字符即用户输入了空格,代码为【if (strings.replace(/(^s*)|(s*$)..】。…

    2025年3月7日
    200
  • js怎么判断数组长度

    在JavaScript中,可以使用length属性来判断并返回数组长度,语法格式“arrayObject.length”;length属性可以返回数组的最大长度,即其值等于数组最大下标值加1。 本教程操作环境:windows7系统、ECMA…

    2025年3月7日
    200
  • javascript和typescript的区别是什么

    区别:1、TypeScript中的数据要求带有明确的类型,JavaScript不要求。2、TypeScript引入了JavaScript中没有的“类”概念。3、TypeScript通过类型注解提供编译时的静态类型检查。 本教程操作环境:wi…

    2025年3月7日
    200
  • 值得收藏的11个对开发有帮助的 JS 技巧

    本篇文章给大家分享11 个对开发有帮助的 js 技巧。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 相关推荐:JavaScript视频教程 1. 生成一个带有随机数的列表 Array.from({ length: 100…

    2025年3月7日
    200
  • JavaScript专题之一:变量提升与预编译

    目录 前言一、有趣的现象二、Js的预解析三、提升之间的优先级四、ES6 写在最后 (相关免费学习推荐:javascript视频教程) 前言 立即学习“Java免费学习笔记(深入)”; 本篇文章是《JavaScript专项进阶系列》的第一篇文…

    2025年3月7日 编程技术
    200
  • javascript怎么判断是否为null

    javascript判断是否为null的方法:1、通过“if (value === null) {…}”方法进行判断;2、通过“if (!value && typeof value !=”undefi…

    2025年3月7日
    200
  • js怎么删除数组中某一元素

    js删除数组中某一元素的方法:首先获取指定元素在数组中的位置(即索引index);然后使用splice()函数根据索引值来删除数组中的元素,语法格式“splice(index, 1)”。 本教程操作环境:windows7系统、ECMAScr…

    2025年3月7日
    200

发表回复

登录后才能评论