详解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 相关文章推荐
一款基于css3的动画按钮代码教程
Nov 23 HTML / CSS
CSS3中的Media Queries学习笔记
May 23 HTML / CSS
CSS3实现翘边的阴影效果的代码示例
Jun 13 HTML / CSS
CSS实现雨滴动画效果的实例代码
Oct 08 HTML / CSS
html5 input元素新特性_动力节点Java学院整理
Jul 06 HTML / CSS
详解Canvas事件绑定
Jun 27 HTML / CSS
利用html5 canvas破解简单验证码及getImageData接口应用
Jan 25 HTML / CSS
HTML5之SVG 2D入门13—svg对决canvas及长处和适用场景分析
Jan 30 HTML / CSS
HTML5 embed标签定义和用法详解
May 09 HTML / CSS
Canvas制作的下雨动画的示例
Mar 06 HTML / CSS
html5简介及新增功能介绍
May 18 HTML / CSS
HTML通过表单实现酒店筛选功能
May 18 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 fckeditor 调用的函数
2009/06/21 PHP
PHP中file_exists()判断中文文件名无效的解决方法
2014/11/12 PHP
详解PHP发送邮件知识点
2018/05/06 PHP
laravel5 Eloquent 实现事务方式
2019/10/21 PHP
动态加载js的几种方法
2006/10/23 Javascript
javascript中slice(),splice(),split(),substring(),substr()使用方法
2015/03/13 Javascript
Bootstrap项目实战之首页内容介绍(全)
2016/04/25 Javascript
VUE开发一个图片轮播的组件示例代码
2017/03/06 Javascript
JS排序之冒泡排序详解
2017/04/08 Javascript
AngularJS折叠菜单实现方法示例
2017/05/18 Javascript
MvcPager分页控件 适用于Bootstrap
2017/06/03 Javascript
JavaScript 有用的代码片段和 trick
2018/02/22 Javascript
element-ui组件table实现自定义筛选功能的示例代码
2019/03/15 Javascript
详解微信小程序胶囊按钮返回|首页自定义导航栏功能
2019/06/14 Javascript
javascript执行上下文、变量对象实例分析
2020/04/25 Javascript
[02:13] 完美世界DOTA2联赛PWL DAY5集锦
2020/11/03 DOTA
python爬虫自动创建文件夹的功能
2018/08/01 Python
浅谈django rest jwt vue 跨域问题
2018/10/26 Python
人工神经网络算法知识点总结
2019/06/11 Python
python里 super类的工作原理详解
2019/06/19 Python
Python3.6实现根据电影名称(支持电视剧名称),获取下载链接的方法
2019/08/26 Python
完美解决Django2.0中models下的ForeignKey()问题
2020/05/19 Python
Python利用matplotlib绘制折线图的新手教程
2020/11/05 Python
python中append函数用法讲解
2020/12/11 Python
预订从美国飞往印度的机票:MyTicketsToIndia
2017/05/19 全球购物
Hoover胡佛官网:美国吸尘器和洗地机品牌
2019/01/09 全球购物
explicit和implicit的含义
2012/11/15 面试题
事业单位接收函
2014/01/10 职场文书
肖申克救赎观后感
2015/06/02 职场文书
法律讲堂观后感
2015/06/11 职场文书
大学生安全教育心得体会
2016/01/15 职场文书
高效课堂教学反思
2016/02/24 职场文书
2016年119消防宣传日活动总结
2016/04/05 职场文书
pytorch中[..., 0]的用法说明
2021/05/20 Python
pytorch中Schedule与warmup_steps的用法说明
2021/05/24 Python
python中的class_static的@classmethod的巧妙用法
2021/06/22 Python