国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 開發 > HTML5 > 正文

詳解HTML5如何使用可選樣式表為網站或應用添加黑暗模式

2024-09-05 07:23:22
字體:
來源:轉載
供稿:網友

為你的站點添加黑暗模式

黑暗模式 已經應用在了許多流行的網站和應用程序中,諸如 Twitter、Instagram、WhatsApp 和 YouTube 等。但是你該怎樣在自己的網站上添加這種模式呢?

我一直非常喜歡動態的網站顏色主題切換器。它們可以讓你選擇自己喜歡的顏色主題,從而改善了用戶體驗!

例如,下面是在 Twitter 的“顯示設置”下找到的顏色主題選項。

這次就讓我們來創建與之類似的功能吧。也許它不會像 Twitter 的主題更改器那么高大上,但我們會講明白這里會用到的技術細節,告訴大家如何使用可選樣式表(alternate style sheets)和 JavaScript 來切換 CSS 所包含的主題定義。

首先……我們來看一下這篇文章要創建出什么樣的內容。

下面是一個可以切換本網站顏色主題的運行示例:

https://www.javascriptteacher.com/dark-mode-alternate-css-style-sheet.html?rt

單擊各個按鈕就可以立即切換整個網站的 CSS 主題。在本教程的剩余部分,我將向你展示如何向你自己的站點添加黑暗模式功能!

如果你能抓取到這篇黑暗模式教程頁面使用的可選樣式表,那也可以復制到你自己制作的網站上,或者用在你的 Wordpress(或類似的站點構建工具)中。

你可能聽說過 CSS 可以是 內聯 的,內部 的和 外部 的。這決定了 CSS 包含在你的文檔中的方式。但是為了理解可選樣式表的概念,我們首先需要看一下……

層疊樣式表的 3 種類型

但是,層疊樣式表(也就是 CSS)還有其他三種形式。它們分別是 持久 的,首選 的和 可選 的。

持久樣式 指的是始終啟用的 CSS 樣式,并與活動樣式表結合在一起。為了指定持久樣式表,需要將 rel = "stylesheet" 屬性添加到你的 link 標簽,并跳過 title 屬性。

這就是你指定一個樣式表的常規方式。

<!-- Persistent Style Sheet --> <link src = "style.css" rel = "stylesheet" 

首選樣式 是頁面加載完成后啟用的默認樣式。要創建它,請向你的 CSS link 標簽添加 title 屬性。

<!-- Alternate Style Sheet (just add a title) --> <link src = "dark.css"       rel = "stylesheet"     title = "dark" /> 

可選樣式 可以實時切換來更改頁面主題,而無需重新加載頁面。

<!-- Dark Mode Alternate Style Sheet --> <link src = "dark.css"     title = "dark" />       rel = "alternate stylesheet" /> <!-- Light Mode Alternate Style Sheet --> <link src = "light.css"     title = "light"       rel = "alternate stylesheet" /> 

為了創建可選樣式表,你要做的就是將 link 標簽中的 rel 屬性設置為“alternate stylesheet”。就這樣即可。這只是第一步。現在我們需要編寫一個腳本來切換樣式表。

在樣式表之間動態切換

我在做相關研究時,在網上發現了不少有些年頭的可選樣式表 JavaScript 函數。但是它們有點過時了,所以我自己寫了一個版本。

最重要的是,你需要在要啟用的可選樣式表對象上將屬性 disabled 設置為 false。

<!-- Switch to a named alternate stylesheet --> function setActiveStyleSheet(title) {     let css = `link[rel="alternate stylesheet"]`;     let stylesheets = document.querySelectorAll(css);     stylesheets.forEach(sheet => sheet.disabled = true);     let selector = `link[title="${title}"]`;     let stylesheet = document.querySelector(selector);     stylesheet.disabled = false; 

要動態切換到新樣式表上,首先你必須禁用所有可用的可選樣式表。如果你沒能做到這一點,則會發現你的可選樣式表不起作用(無法切換)。因此,在這個函數的第一步中,我們禁用了所有可用的可選樣式表。完成后,我們啟用了 title 參數中指定的那個。

<!-- Attach event to a button -->     let DarkModeButton = document.getElementById("DarkModeButton");     DarkModeButton.addEventListener("click",         event => setActiveStyleSheet("darkmode")); 

你可以將 setActiveStyleSheet 函數作為回調附加到負責切換它的按鈕的“click”事件上。請注意,上面的示例假設我們有一個 title = "darkmode" 的樣式表。或者,你可以直接在元素上直接使用 onclick 屬性即可:

<div id = "DarkModeButton" onclick = "setActiveStyleSheet('darkmode')"> 

就動態切換 CSS 樣式表需要的工作來說,到這里就都完成了。但是還有一件事!如果用戶在選擇其他主題之后離開站點,則需要確保當用戶返回時網站加載了他們最后選擇的那個主題。這可以使用 cookie 來實現,但是在本教程中,我將使用 HTML5 localStorage 來完成它。

記憶所選主題

我們可以使用 localStorage 來記住用戶之前所選擇的主題。這里的代碼是直截了當的。每次選擇主題時,我們都會將其標題名稱存儲在名為 "theme" 的 localStorage 項目中。下面我們來更新上一步中已經編寫好的那個函數:

<!-- Switch to a named alternate stylesheet --> function setActiveStyleSheet(title) {     let css = `link[rel="alternate stylesheet"]`;     let stylesheets = document.querySelectorAll(css);     stylesheets.forEach(sheet => sheet.disabled = true);     let selector = `link[title="${title}"]`;     let stylesheet = document.querySelector(selector);     stylesheet.disabled = false;     localStorage.setItem("theme", title); } 

請注意,這里我們添加了一個新的 localStorage 調用。現在,每次切換到一個可選樣式表上時,它將存儲在關鍵字 "theme" 下。

現在,如果用戶離開站點并(在關閉瀏覽器選項卡之后)再次進入站點,我們需要恢復保存在 localStorage 中的默認主題。

為了做到這一點,我們需要從 DOMContentLoaded 事件上讀取本地存儲(時間就在 DOM 加載完畢之后不久),并使用存儲在主題項目中的值來選擇樣式表:

<!-- Switch to a named alternate stylesheet --> window.addEventListener('DOMContentLoaded', (event) => {     console.log('DOM fully loaded and parsed');     let title = localStorage.getItem("theme");     setActiveStylesheet(title); }) 

這樣就搞定啦!現在,你有了一個完整的,可選 CSS 主題的主題選擇器。當然比較困難的部分是制作一套漂亮的 CSS 布局,但這塊內容就等下一篇教程來具體講解吧!

到此這篇關于詳解HTML5如何使用可選樣式表為網站或應用添加黑暗模式的文章就介紹到這了,更多相關HTML5黑暗模式內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产综合视频一区二区三区免费| 黄色av网址在线免费观看| 国产美女在线免费观看| 久久国产综合视频| 国产卡1卡2卡三卡在线| 中文字幕色视频| 99免费视频| 久久久久久77777| 国产激情网址| 开心快乐六月丁香婷婷| 国产一区二区三区四区尤物| 国产特级淫片免费看| 18av在线视频| 全网国产福利在线播放| 亚洲视频精品在线观看| 1区2区3区在线| 亚洲视频在线观看不卡| 天堂资源最新在线| 香蕉视频在线观看www| 中文字幕在线观看日本| 亚洲精品成人a| 国产黄色免费网| 国产中文在线视频| 99色在线观看| 国产视频第一区| 激情六月婷婷| 性网站在线看| 精品无人区乱码1区2区3区免费| 久热国产在线| 国产激情视频一区二区三区| 日本aⅴ写真网站免费| 国产福利图片| 国产欧美日本亚洲精品一4区| 精品孕妇一区二区三区| 亚洲成人av在线影院| 国产精品剧情一区二区在线观看| 天天操人人干| 天堂在线亚洲| 天天操人人爽| 中文字幕在线免费| 国产美女性感在线观看懂色av| 亚洲sss视频| 亚洲人成影院在线| av在线日韩国产精品| 国产黄在线看| 国产系列电影在线播放网址| 久久久久久久久久久久久91| 久热中文字幕精品视频在线| 超碰在线观看免费| 福利在线观看| 国产精品麻豆一区二区三区| 2019天天操夜夜操| 午夜影院在线| 激情四房婷婷| 88av在线| 精品久久久久一区二区三区| 亚洲网站一区| 国产美女免费观看| 国产精品你懂的在线观看| 国产精品一区二区三区视频网站 | 国产精品伦理一区二区三区| 国产精品第八页| 伊人国产在线看一| 蜜桃视频中文字幕| 国产特级淫片免费看| 精品999视频| 国内自拍视频在线观看| 国产一区二区三区福利| 中文天堂av| 激情丁香婷婷| 18激情网站| 久色视频在线观看| 国产黄在线观看| 老司机精品视频一区二区| 最新中文字幕在线| 欧美啪啪精品| 在线观看中文字幕的网站| 国产专区在线播放| av中文在线| 国产爆初菊在线观看免费视频网站 | 国产麻豆高清视频在线第一页| 国产丝袜护土调教在线视频| 一本大道香蕉久久| 国产精品视频二区三区| 青娱乐在线视频观看| 91在线视频免费看| 国产午夜三区视频在线| 久久er视频| 免费在线黄色av| jlzzjlzz欧美大全| 在线国产1区| 国产成人亚洲欧美电影| 国产农村一级特黄α**毛片 | 免费在线看v| 亚洲精品久久久成人| 国产黄色高清在线| 国产一起色一起爱| 国产鲁鲁视频在线观看免费| 青青在线视频| 超碰在线免费播放| 国内自拍视频在线观看| 欧美xxxx黑人又粗又长| av免费在线观看网站| 国产不卡视频| 在线播放一区二区精品产| 国产精品久久久久白浆| 超碰在线中文| 五月婷婷导航| 国产黄色在线| 永久av在线| 免费黄色网页在线观看| 久久久久久国产视频| 国产精品一品| 国产超碰97| 欧美日韩亚洲国内综合网| 免费在线高清av| 高潮毛片在线观看| 国产精品久久久久久久牛牛| 国产精品久久久久久精| 中文乱码字幕高清在线观看| 一本久中文高清| av资源网站在线观看| 天天av天天爽| 精品无人乱码| 国产在线三区| 国产h在线观看| 免费的黄网站在线观看| 国产精品入口麻豆高清| www.操操操| 国产精品视频一区二区免费不卡| av在线不卡网站| 国产桃色电影在线播放| 人人澡人人爽| 69日小视频在线观看| 免费在线黄色av| 91社区在线观看| 人人干在线视频| 97在线超碰| 国产精品剧情一区二区在线观看| www中文字幕在线观看| 97视频网站| 国产精品扒开做爽爽爽的视频 | av网站大全在线| 国产精品日日爱| 国产乱视频在线观看播放| 樱花草在线观看www| 国产精品臀控福利在线观看| 夜夜爽夜夜操| 精品无吗乱吗av国产爱色| 午夜视频在线观看网站午夜视频在线 | 欧美韩日国产| 99re在线视频播放| 国产三级做爰在线观看| 黄网在线免费| 开心激情五月婷婷| 日本a级黄色| 亚洲va国产日韩欧美精品色婷婷| 国产精品黄页网站在线播放免费| 欧美日韩在线精品成人综合网| 精品国产美女福利到在线不卡| 国产小视频福利在线| 狠狠综合久久久综合| av免费在线观| 性国产高清在线观看| 在线播放黄色网址| 色欧美在线观看| 秋霞av在线| 国产中文在线视频| 国产免费福利网站| 国产一二三区在线观看| 国产一区二区三区四区尤物| 中文字幕在线影视资源| 中文字幕久热在线精品| 国产极品视频| 一区免费观看| 六月天色婷婷| 国产三级在线观看| 91国内精品在线视频| 天堂√中文在线| 国产精品自拍亚洲| 精品乱码一区二区三四区视频| 精品美女在线观看视频在线观看| 在线天堂中文www视软件| sese在线视频| √天堂8资源中文在线| 91av福利| 浪潮av一区| 国产精品久久久久久久牛牛| 亚洲免费网站在线观看| 老司机在线视频二区| 国产一级免费| av亚洲在线| 国产在线激情视频| 国产a级网站| 尤物视频在线免费观看| 性网站在线看| 国产经典自拍视频在线观看| 久草在线视频网| 樱花草在线观看www| 国产色a在线|