基础前端

CSS accent-color

2021-11-08  本文已影响0人  CondorHero
image.png

翻译自:https://web.dev/accent-color/

更改复选框的强调色

一般我们的复选框长成下面这样,现在要求你切深色模式的时候,更改复选框选中的强调色为粉色。

审查元素,你发现 Checkbox 是原生 HTML 标签写的,这个时候你挠挠头,想了想 CSS 好像没有更改强调色的属性,没办法,只能自己来自定义了,但是重新自己写问题很大,从头开始构建它最终会比预期的工作多得多,即使用第三方框架也不是最理想的解决方案,浏览器万一更新新增效果就扯犊子了。

最好的解决方案还是利用 CSS 属性来解决。这就是我们的主角:

accent-color: auto | <color>;

接下来给出实现的源码:

<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>更改复选框的强调色</title>
</head>
<body>
    <input type="checkbox" style="accent-color: hotpink;"/>
</body>
</html>

支持的元素

问题来了,这么好用的 CSS 属性,难道就只支持复选框吗?那肯定不成本着好东西多用,它支持四个元素:checkboxradiorangeprogress。每个都可以在此处以浅色和深色配色方案预览 https://accent-color.glitch.me

image.png

兼容性

通过 https://caniuse.com/?search=accent-color 查询 accent-color 的兼容性很一般,但是你要知道,即使是不支持的浏览器,你写了 CSS 语法是不会报错的,所以作为增强使用完全没问题。

参考

上一篇下一篇

猜你喜欢

热点阅读