主要原理是利用css变量设置颜色,用js动态修改变量,使颜色变化,兼容性以下;javascript
实现换肤以前先要了解一下伪类选择器 :root
,还有css的 var()
函数和 setProperty()
函数css
:root
是一个伪类,表示文档根元素,非IE及IE8及以上浏览器都支持,在 :root
中声明至关于全局属性,只要当前页面引用了 :root
所在的文件,均可以使用css var()
函数来引用;html
语法java
// 自定义属性的名称,必需以 -- 开头 :root{ --main_bg:#1E90FF; --main_color:rgba(0,100,200,1); }
var()
函数,能够代替元素中,任何属性中的值的任何部分;var()
函数不能做为属性名、选择器或者其余除了属性值以外的值,这样作一般会产生无效的语法或者一个没有关联到变量的值;git
语法github
// var(--name,value) // --name,自定义属性的名称,必需以 -- 开头; value,可选,备用值,在属性不存在的时候使用; .box{ background-color: var(--main_bg); color: var(--box_color, red); border: var(--box_border,10px solid #000000); }
setProperty()
方法用于设置一个新的 css 属性,同时也能够修改 css 声明块中已存在的属性,兼容性以下;
小程序
语法微信小程序
let box = document.querySelector("#box").value; document.documentElement.style.setProperty("--main_bg",box);
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>换肤</title> <style> *{ margin: 0;padding: 0; } #head{ height: 300px;border-bottom:1px solid gray; } #btn{ width: 100px;height: 40px;border-radius: 4px;text-align: center;line-height: 40px;color: #FFFFFF;cursor: pointer;margin-left: calc(50% - 50px); } #ipt{ width: 100%;height: 40px;line-height: 40px;font-size: 20px; text-align: center; border-right: none;border-left: none;} :root{ --main_bg:#1E90FF; } .color{ background-color: var(--main_bg); } </style> </head> <body> <div id="head" class="color"></div> <div id="body"> <input type="text" id="ipt" placeholder="请输入颜色值"> <div id="btn" class="color" onclick="changeBg()">变色</div> </div> <script> function changeBg(){ let color = document.querySelector("#ipt").value; document.documentElement.style.setProperty("--main_bg",color); } </script> </body> </html>
若是看了以为有帮助的,我是@鹏多多,欢迎 点赞 关注 评论;
END浏览器
往期文章服务器
我的主页