详解Html5项目适配系统深色模式方案总结


Posted in HTML / CSS onApril 14, 2021

一、背景

随着 iOS 13 的发布,深色模式(Dark Mode)越来越多地出现在大众的视野中,支持深色模式已经成为现代移动应用和网站的一个潮流,前段时间更是因为微信的适配再度引起热议。深色模式不仅可以大幅减少电量的消耗,减弱强光对比,还能 提供更好的可视性和沉浸感。

如何切换深色模式

  • iOS:“设置”–“显示与亮度”–“外观”,选择“深色”
  • Android:“系统设置”–“显示”–“深色模式”。

二、问题

如果系统设置了深色模式,H5页面不做相应的处理,会出现背景色冲突、深色文字显示异常,深色图标显示异常等一些显示上的问题。

所以,需要对深色模式进行一些适配。

我尝试了一些方案:

三、H5项目适配深色模式方案

1.声明 color-scheme

color-scheme

有两种方式。

1.1meta

在head中声明<meta name="color-scheme" content="light dark"> ,声明当前页面支持 light 和 dark 两种模式,系统切换到深色模式时,浏览器默认样式也会切换到深色;

1.2CSS

下面的 css 同样可以实现上面 meta 声明的效果

:root {
    color-scheme: light dark;
}

注意:此声明并非为页面做自动适配,只影响浏览器默认样式

更多信息可查阅 W3C 文档 《CSS Color Adjustment Module Level 1》

2.通过 CSS 媒体查询

prefers-color-scheme

CSS 媒体特性用于检测用户是否有将系统的主题色设置为亮色或者暗色。

no-preference
表示系统未得知用户在这方面的选项。在布尔值上下文中,其执行结果为 false。

light
表示用户已告知系统他们选择使用浅色主题的界面。

dark
表示用户已告知系统他们选择使用暗色主题的界面。

:root {
    color-scheme: light dark;
    background: white;
    color: black;
}

@media (prefers-color-scheme: dark) {
    :root {
        background: black;
        color: white;
    }
}
//颜色较多的情况,建议使用CSS变量对颜色值进行管理

3.图片适配

利用picture+source标签,设置不同模式下的图片 url。

HTML <picture>元素通过包含零或多个 <source> 元素和一个 <img> 元素来为不同的显示/设备场景提供图像版本。
浏览器会选择最匹配的子 <source> 元素,如果没有匹配的,就选择 <img> 元素的 src 属性中的URL。然后,所选图像呈现在<img>元素占据的空间中。

<picture>
    <!-- 深色模式下的图片 -->
    <source srcset="dark.jpg" media="(prefers-color-scheme: dark)" />
    <!-- 默认模式下的图片 -->
    <img src="light.jpg"/>
</picture>

4. JavaScript中判断当前模式&监听模式变化

4.1matchMedia

Window 的matchMedia() 方法返回一个新的MediaQueryList 对象,表示指定的媒体查询 (en-US)字符串解析后的结果。返回的MediaQueryList 可被用于判定Document是否匹配媒体查询,或者监控一个document 来判定它匹配了或者停止匹配了此媒体查询。

4.2addListener()
MediaQueryList接口的addListener()方法向MediaQueryListener添加一个侦听器,该侦听器将运行自定义回调函数以响应媒体查询状态的更改。

JavaScript监听判断

const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)')

function darkModeHandler() {
    if (mediaQuery.matches) {
        console.log('现在是深色模式')
    } else {
        console.log('现在是浅色模式')
    }
}

// 判断当前模式
darkModeHandler()
// 监听模式变化
mediaQuery.addListener(darkModeHandler)

到此这篇关于详解Html5项目适配系统深色模式方案总结的文章就介绍到这了,更多相关Html5深色模式内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
你不知道的5个HTML5新功能
Jun 28 HTML / CSS
html5文本内容_动力节点Java学院整理
Jul 11 HTML / CSS
一张图片能隐含千言万语之隐藏你的程序代码
Dec 13 HTML / CSS
利用HTML5中Geolocation获取地理位置调用Google Map API在Google Map上定位
Jan 23 HTML / CSS
HTML5之SVG 2D入门3—文本与图像及渲染文本介绍
Jan 30 HTML / CSS
html5摇一摇代码优化包括DeviceMotionEvent等等
Sep 01 HTML / CSS
html5+css3进度条倒计时动画特效代码【推荐】
Mar 08 HTML / CSS
浅谈Html5多线程开发之WebWorkers
May 02 HTML / CSS
data:image data url 文件转为Blob上传后端的方法
Jul 16 HTML / CSS
详解HTML5如何使用可选样式表为网站或应用添加黑暗模式
Apr 07 HTML / CSS
h5移动端调用支付宝、微信支付的实现
Jun 08 HTML / CSS
详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)
Jul 01 HTML / CSS
css3实现背景图片半透明内容不透明的方法示例
CSS3 实现的图片悬停的切换按钮
Apr 13 #HTML / CSS
纯CSS实现酷炫的霓虹灯效果
CSS3实现三角形不断放大效果
css3实现背景图片颜色修改的多种方式
Apr 13 #HTML / CSS
CSS3 制作的悬停缩放特效
Apr 13 #HTML / CSS
CSS3 制作的书本翻页特效
You might like
php截取utf-8中文字符串乱码的解决方法
2010/03/29 PHP
PHP 图片上传实现代码 带详细注释
2010/04/29 PHP
php 伪静态之IIS篇
2014/06/02 PHP
部署PHP时的4个配置修改说明
2015/10/19 PHP
php readfile下载大文件失败的解决方法
2017/05/22 PHP
详解php框架Yaf路由重写
2017/06/20 PHP
PHP的PDO错误与错误处理
2019/01/27 PHP
javascript 表单的友好用户体现
2009/01/07 Javascript
jquery简单实现鼠标经过导航条改变背景图
2013/12/17 Javascript
DWR中各种java方法的调用
2016/05/04 Javascript
vue.js入门教程之基础语法小结
2016/09/01 Javascript
jQuery实现的导航下拉菜单效果示例
2016/09/05 Javascript
关于Vue的路由权限管理的示例代码
2018/03/06 Javascript
解决vue打包css文件中背景图片的路径问题
2018/09/03 Javascript
小程序显示弹窗时禁止下层的内容滚动实现方法
2019/03/20 Javascript
微信小程序用户授权、位置授权及获取微信绑定手机号
2019/07/18 Javascript
[02:01]大师之路——DOTA2完美大师赛11月论剑上海
2017/11/06 DOTA
python 算法 排序实现快速排序
2012/06/05 Python
python打开url并按指定块读取网页内容的方法
2015/04/29 Python
详解Python的Django框架中Manager方法的使用
2015/07/21 Python
Python中字符串的格式化方法小结
2016/05/03 Python
Python之web模板应用
2017/12/26 Python
python并发编程之线程实例解析
2017/12/27 Python
Python自定义一个类实现字典dict功能的方法
2019/01/19 Python
Python使用Chrome插件实现爬虫过程图解
2020/06/09 Python
HTML5 Web 存储详解
2016/09/16 HTML / CSS
英国领先的品牌珠宝和配件供应商:Acotis Jewellery
2018/03/07 全球购物
现代绅士日常奢侈品:Todd Snyder
2019/12/13 全球购物
Shopping happy life西班牙:以最优惠的价格提供最好的时尚配饰
2020/03/13 全球购物
Happy Plugs官网:瑞典无线耳机品牌
2020/07/16 全球购物
实习生自荐信范文分享
2013/11/27 职场文书
护士自我鉴定总结
2014/03/24 职场文书
安全保证书
2015/01/16 职场文书
2015年美容师个人工作总结
2015/10/14 职场文书
初中班级口号霸气押韵
2015/12/24 职场文书
Python基础学习之奇异的GUI对话框
2021/05/27 Python