簡單的JS+CSS實現網頁自定義換膚

1,實現效果

在這裏插入圖片描述

2,實現原理


主要原理是利用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);

3,完整代碼


<!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
瀏覽器

往期文章服務器

我的主頁

相關文章
相關標籤/搜索