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

jquery支持按住Shift键来选择连续的复选框数据插件

一款table表格支持shift键多选插件,可通过按住Shift键并单击相关的复选框来选择/取消选择table表格中的多行。
  其它&杂项
 9834  0

jquery监听input文本框输入更改事件

Textchange.js插件提供了一个文本更改监听事件,每次更改文本字段中的值时都会触发该事件,同步输出输入的值。
  其它&杂项
 7860  0

jquery多层多区域拖拽插件

一款多层多区域拖拽小插件,可自定义多区域,拖拽图片悬停在某个区域上放手,会自动吸附归位,样式完全自定义。
  其它&杂项
 31449  0

jquery带拖动的进度条播放停止代码

一款可控制进度条的脚本特效,带开始和停止按钮,超实用的功能。
  其它&杂项
 51074  0

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

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