首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

css中的“var`”在IE中不起作用

在 Internet Explorer 浏览器(IE)中,CSS 自定义属性(也称为 CSS 变量)是不受支持的,这就是为什么使用 var() 函数设置 CSS 变量在 IE 浏览器中不起作用的原因。CSS 变量是一个相对较新的特性,IE 浏览器没有跟上 Web 标准的发展,因此不支持这一特性。

然而,你可以使用一些替代方法在 IE 浏览器中实现类似的功能(变量)。以下是一些建议:

1. 使用 PostCSS 插件

对于构建流程中的 CSS,可以使用 PostCSS 插件,比如 postcss-custom-properties ,将 CSS 变量转换为包含静态值的 CSS。这样,转换后的 CSS 可以在 IE 浏览器中正常工作。

为了使用这个插件,你需要安装它并将其添加到你的构建流程中:

代码语言:javascript
复制
shnpm install postcss-custom-properties --save-dev

然后,在你的 PostCSS 配置中添加这个插件:

代码语言:javascript
复制
javascriptconst postcssCustomProperties = require('postcss-custom-properties');

module.exports = {
  plugins: [
    postcssCustomProperties(/* options */)
  ]
};

2. 使用 JavaScript 做后备

针对简单场景,你可以用一些 JavaScript 或 jQuery 添加后备方案。例如,可以利用一些库例如 Modernizr 检测浏览器对 var() 支持程度。

代码语言:javascript
复制
javascriptif (!Modernizr.cssvariables) {
  // 使用 jQuery 或其他库进行 CSS 变量的后备方案
  $('html').css('font-size', '16px'); // IE */ 
  $('html').css('--font-size', '16px'); // 其他现代浏览器
}

结合这些后备方案确保 CSS 变量在 IE 浏览器和其他现代浏览器中都能正常工作,实现跨浏览器兼容。

3. 使用 CSS 预处理器

另外一种选项是使用像 Sass 或 Less 这样的 CSS 预处理器。它们允许你使用变量来定义和重复值。虽然这并不能完全替代 CSS 变量,但可以在 IE 浏览器中避免 var() 不被支持的问题。

例如,在 Sass 中:

代码语言:javascript
复制
scss$font-size: 16px;

body {
  font-size: $font-size;
}

总之,虽然 CSS 变量在 IE 浏览器中不受支持,但你可以使用一些方法来提高浏览器的兼容性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

CSS3中的变量var了解

关于命名这个东西,各种语言都有些显示,例如CSS选择器不能是数字开头,JS中的变量是不能直接数值的,但是,在CSS变量中,这些限制通通没有,例如: :root{ --main-bg-color:...{ --color: 20px; background-color: #369; background-color: transparent; } css变量在js中的应用 看如下例子...浏览器的兼容如图所示: 到目前位置IE11也不支持该css变量。 说到这儿感觉这个css变量也是很强大的,那么它跟预处理器比较,你觉得哪个更好?下面讲一下预处理器的劣势。...是否应该限制在块中? 由于CSS最终目的是为HTML添加样式,事实证明还有另一种有效的方法给变量限定作用域:DOM元素。但由于预处理器不在浏览器中运行并且无法看到标记,它们不能这样做。...下面给一个css变量在媒体查询中的使用: :root { --gutter: 1.5em; } @media (min-width: 30em) { :root { -

1.4K30
  • 为什么 strace 在 Docker 中不起作用?

    在编辑“容器如何工作”爱好者杂志的能力页面时,我想试着解释一下为什么 strace 在 Docker 容器中无法工作。...这里的问题是 —— 如果我在笔记本上的 Docker 容器中运行 strace,就会出现这种情况: $ docker run -it ubuntu:18.04 /bin/bash $ # ... install...但这实际上是不合理的,原因有两个。 原因 1:在实验中,作为一个普通用户,我可以对我的用户运行的任何进程进行 strace。...这个问题其实并不相关,但这是我观察时想到的。 容器进程是否在不同的用户命名空间中?嗯,在容器中: root@e27f594da870:/# ls /proc/$$/ns/user -l ......在 containerd 的 seccomp 实现中,在 contrib/seccomp/seccomp/seccomp_default.go 中,有一堆代码来确保如果一个进程有一个能力,那么它也会(通过

    6.4K30

    在.NET中警惕C#的is var写法

    F2={f2}"); } 答案是控制台居然输出居然进来了,也就是说 null 在 is 判断里面是通过,而 var 的含义似乎不只是一个语法上的可有可无的关键词而已,而是赋予了运行时含义的关键词 换句话说就是在以上代码里面的...最初的 C# 里面的 var 只是一个在构建过程中可以被平替为具体类型的关键词,是一个不会影响到语义、运行时逻辑的语法而已。...然而在 is 这里面,将 var 当成了一个可以处理空值的特殊语法结构 这和咱长久的使用 is 来过滤空值的编程思想是冲突的,我感觉绝大部分开发者在写到 is var 的过程,将会想着应该是自动过滤掉...难道有这么多的开发者大佬脑袋都被大门夹了? 整个 C# 语言的设计是在不断迭代的,现在已经是 C# 12 了。...} return false; } 如此可以看来 is var 的设计还是在一些逻辑上可以很好的减少代码量的 这个 is var 的决议最早的有记录的会议可以追溯到 2015

    13810

    IE中的内存泄露

    参考文章: Winter 的《浏览器中的内存泄露》 鸟食轩的《理解并解决IE内存泄露的方式[翻译]》 IBM的《JavaScript中的内存泄露模式》 还有两篇文章: IE's memory-leak...fix greatly exaggerated Memory Leakage in Internet Explorer – revisited IE中内存泄露的几种方式: 1、循环引用(Circular...References) — IE浏览器的COM组件产生的对象实例和网页脚本引擎产生的对象实例相互引用,就会造成内存泄漏。...(如监听onclck事件的方法);只是如果你不小心在代码中写下与上面相似的代码,那么它就可能已经产生内存泄露了。...好在还有一个工具:Javascript Leaks Detector JLD的强大之处在于能够模拟IE6和IE7的GC情况,和真实的回收情况。这样可以做一个比较。

    96940

    PHP 中 var_export、print_r、var_dump 调试中的区别

    : var_export ≈ print_r var_dump 2、调试的时候,调用 var_export、print_r、var_dump 的时候, 不用 在前加 echo 。...3、var_export,print_r 的 第二个参数为true则返回值。var_dump 不支持 ,所以用 file_put_contents 输出调试的时候不要用 var_dump。...4、推荐开发环境的调试直接使用 var_dump,可以获得详细的调试信息和代码行数定位;生产环境的调试使用 var_export 或 print_r,第二个参数记得设置为 true 转为返回输出值,而不是直接输出到前端影响线上...总结 以上所述是小编给大家介绍的PHP 中 var_export、print_r、var_dump 调试中的区别,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。...在此也非常感谢大家对开源独尊的支持!

    94420

    在HTML中如何使用CSS?

    2.3 链接式 在实际的网页设计中,链接式 CSS 用法是最常用的,也是效果最好的。...使用链接式 CSS,可以在设计整个网站时,将多个页面都会用到的 CSS 样式定义在一个或多个 文件中,然后在需要用到该样式的 HTML 网页中通过 标记链接这些 文件,通过链接式 CSS 可以降低整个网站的页面代码冗余并提高网站的可维护性...被导入的 HTML 文件在初始化时,会将该 CSS 文件导入 HTML 文件中,作为此 HTML 文件的一部分,类似于内嵌式的效果,而链接式是在 HTML 的标记需要 CSS 样式的时候才会以链接的方式引入进来...例如,可以在 文件中不写任何 CSS 代码,只写 ,这样所有导入或链接到该 CSS 文件的 HTML 页面都可以使用 中定义的所有样式效果。...这时解决 CSS 冲突你就要了解在 HTML 中使用 CSS 的优先级规则: 内联式 > 内嵌式 > 外部样式; 在多个样式中,后出现的样式的优先级高于先出现的样式; 在样式中,选择器的优先级: 样式

    8.5K100

    List.append() 在 Python 中不起作用,该怎么解决?

    在 Python 中,我们通常使用 List.append() 方法向列表末尾添加元素。然而,在某些情况下,你可能会遇到 List.append() 方法不起作用的问题。...问题描述虽然 List.append() 方法通常在 Python 中运行良好,但在某些情况下,它可能无法正常工作。以下是一些可能导致 List.append() 方法不起作用的情况:1....变量重新赋值在 Python 中,列表是可变对象,也就是说,它们可以通过引用进行修改。...列表作为函数参数另一个导致 List.append() 方法不起作用的常见情况是将列表作为函数的参数传递。在 Python 中,函数参数传递是通过对象引用实现的。...结论List.append() 方法在 Python 中通常是一个方便且常用的方法,用于向列表末尾添加元素。然而,当遇到某些情况时,它可能不起作用。

    2.7K20

    Java中var的使用方法

    前言var是JDK10之后推出的语法糖,用它来定义局部变量,并且var可以进行局部变量类型推断var 使用例如用var定义一个int变量typescript 代码解读复制代码public class VarDemo...使用要注意的点1、var不能定义变量typescript 代码解读复制代码public class Var2Demo { public static void main(String[] args...) { var a ; }}这种会报错2、var只能在方法内定义变量,不允许定义类的成员变量kotlin 代码解读复制代码public class Var2Demo { private...var a;}这种也是不允许的3、不能作为方法入参typescript 代码解读复制代码public class Var2Demo { public void process(var list)...{ }}总结总之,jdk10之后提供使用var方便在开发中使用,提高了程序开发效率,但是在一定程序上可能会降低可读性,合理的利用jdk10提供的var语法糖,可以帮助开发,当然效果因人而异

    9710

    网页|在CSS学习中的问题总结

    为了使页面看起来更美观,我开始着手对CSS的学习,在刚开始的学习过程中也确实遇到了许多问题,现在我把他们集中总结。...解决方案 首先明确我的学习顺序:CSS盒子模型→CSSborder→CSSoutline→CSS margin→CSS padding. boxmodle中遇到的问题: 问题一:(待解决)盒中内容过长会超出盒子...图2.1.4盒子中文本的换行情况 (2)CSS border中遇到的问题: 问题一:(已解决)在学习盒子模型时,对这样一行代码“border:30pxsolid gray”中“solid”一词存在困惑:...不过也可以发现一些规律,那就是在“p.”后面、“{}”之前,是可以跟东西的,比如菜鸟上的实例: ?...结语 在学习H5与CSS的过程中,会遇到很多让人疑惑的地方,我的解决方法是实践与记录。先将问题暂时记在记事本,再在过程中不断试验并记录截图,方便后期总结对比。

    2.3K20

    解决IE中图片缓存的问题

    遇到一件很奇怪的事情:假设有两张图片1.jpg、3.jpg,他们同时放在一个目录下(创建时间一样),后来发现这两张图片的名称命名反了,也就是1.jpg实际应该命名为3.jpg,而3.jpg则应为1.jpg...,便到相应的目录中修改两张图片的名称。...在flash中加载这两张图片,在IE中查看,怎么样去刷新都还是以前的图片(反掉了),我尝试清空缓存,关闭所有进程,重启电脑,第二天来看还是不行,这就让我很郁闷了,一度以为是我电脑的问题,后来仔细想了一下...我试过把请求的URL,粘贴到IE浏览器的地址栏,然后刷新,结果一样,http请求返回都是304(我浏览器设置的是每次请求最新的文件),使用chrome去请求URL,强制刷新图片显示的是正确的。...对于在公网如果有这样的需求,文件命名反掉了,建议最好使用新的名称或是在请求后面加特定的参数(让它返回200的状态)

    1.5K30
    领券