jquery基于bootstrap可自由切换的暗亮模式

所属分类: 网页特效-其它&杂项    2023-11-23 10:44:54

jquery基于bootstrap可自由切换的暗亮模式 ie兼容6
反馈问题  查看演示  登录后下载 温馨提示
登录会员即可享受免费下载
 我要建站

jquery基于bootstrap可自由切换的暗亮模式(共4个文件)

    • index.html

使用方法

function toggleDisplayMode() {
	var e_page_state = document.getElementById("page-display-mode")
	var page_state = e_page_state.innerHTML;

	/* Dark Mode Variables */
	var e_text_dark = document.querySelectorAll(".text-dark");
	var e_text_black = document.querySelectorAll(".text-black");
	var e_bg_dark = document.querySelectorAll(".bg-dark");
	var e_bg_black = document.querySelectorAll(".bg-black");

	/* Light Mode Variables */
	var e_text_light = document.querySelectorAll(".text-light");
	var e_text_white = document.querySelectorAll(".text-white");
	var e_bg_light = document.querySelectorAll(".bg-light");
	var e_bg_white = document.querySelectorAll(".bg-white");

	/* Other Elements */
	var e_cards = document.querySelectorAll(".card");

	// Switch from Light to Dark Mode
	if (page_state == "light") {
		switchClasses(e_text_dark, "text-dark", "text-light");
		switchClasses(e_text_black, "text-black", "text-white");
		switchClasses(e_bg_light, "bg-light", "bg-dark");
		switchClasses(e_bg_white, "bg-white", "bg-black");
		addClass(e_cards, "border-dark");
	}
	// Switch from Dark to Light Mode
	else if (page_state == "dark") {
		switchClasses(e_text_light, "text-light", "text-dark");
		switchClasses(e_text_white, "text-white", "text-black");
		switchClasses(e_bg_dark, "bg-dark", "bg-light");
		switchClasses(e_bg_black, "bg-black", "bg-white");
		removeClass(e_cards, "border-dark");
	}

	// Update page state
	e_page_state.innerHTML = switchState(page_state);
}

function switchClasses(elements, fromClass, toClass) {
	for(let elem of elements) {
		if (elem.classList.contains(fromClass)) {
			elem.classList.remove(fromClass);
			elem.classList.add(toClass);
		}
	}

	return true;
}

function addClass(elements, className) {
	for (let elem of elements) {
		if (!elem.classList.contains(className)) {
			elem.classList.add(className);
		}
	}
}

function removeClass(elements, className) {
	for (let elem of elements) {
		if (elem.classList.contains(className)) {
			elem.classList.remove(className);
		}
	}
}

function switchState(state) {
	switch(state) {
		case "light":
			state = "dark"; 
			break;
		case "dark":
			state = "light";
			break;
		default:
			state = "undefined";
	}

	return state;
}

function createPageStateElement() {
	var div = document.createElement("div");
	var id = "page-display-mode";
	var init_mode = document.createTextNode("light");
	div.appendChild(init_mode)
	div.id = id;
	div.classList.add("d-none");
	document.getElementsByTagName("body")[0].appendChild(div);
}

window.toggleDisplayMode = toggleDisplayMode;
window.createPageStateElement = createPageStateElement;

站长提示:
1. 平台上所有素材资源,需注册登录会员方能正常下载。
2. 会员用户积极反馈网站、素材资源BUG或错误问题,每次奖励20K币
3. PHP源码类素材,如需协助安装调试,或你有二次开发需求,可联系苦力吧客服。
4. 付费素材资源,需充值后方能下载,如有任何疑问可直接联系苦力吧客服
相关资源 / 其它&杂项

纯JavaScript动态添加/修改/删除/获取查询字符串

纯JavaScript动态添加/修改/删除/获取查询字符串
  其它&杂项
 160  

jquery页面定位滚动切换背景色插件

一款鼠标点击定位url自动显示对应内容,并且同时变更页面背景颜色,很不错的特效。
  其它&杂项
 180  

jquery自动根据背景色改变文本文字颜色插件

一款可根据背景色改变文本文字字体颜色插件,自动检查识别当前区域背景颜色,智能的将文本字体颜色设置成最适合的颜色,超实用。
  其它&杂项
 276  

jquery页面滚动导航条吸顶固定浮动特效代码

一款轻量级滚动顶部固定特效插件,当滚动页面滚动条时,导航栏固定于页面顶部位置,并且浮动,非常适用。
  其它&杂项
 152  

评论数(1) 回复有机会获得K币 用户协议

    jq小菜鸡0
    2023-12-08 13:30:41
    这个不就是白天夜晚切换那种吗
    回复
😀
  • 😀
  • 😊
  • 😂
  • 😍
  • 😑
  • 😷
  • 😵
  • 😛
  • 😣
  • 😱
  • 😋
  • 😎
  • 😵
  • 😕
  • 😶
  • 😚
  • 😜
  • 😭
发表评论