前端uni-app移动端开发怎么适配@1x、@2x、@3x图片,直接使用 IMG 的 SRCSET 属性无效

时间: 2024-01-05 08:05:20 浏览: 33
在前端uni-app移动端开发中,可以使用 CSS 的媒体查询和像素比(device pixel ratio)来适配 @1x、@2x、@3x 图片。 具体做法是: 1. 在 CSS 中使用媒体查询,根据不同的屏幕宽度设置不同的图片大小,例如: ```css /* iPhone 6/7/8 */ @media screen and (max-width: 375px) { .my-image { width: 100px; height: 100px; } } /* iPhone 6/7/8 Plus */ @media screen and (min-width: 376px) and (max-width: 414px) { .my-image { width: 120px; height: 120px; } } /* iPad */ @media screen and (min-width: 415px) { .my-image { width: 160px; height: 160px; } } ``` 2. 在 HTML 的 IMG 标签中使用像素比(device pixel ratio),例如: ```html <template> <img :src="getImageSrc()" :srcset="getImageSrcset()"> </template> <script> export default { methods: { getImageSrc() { let pixelRatio = uni.getSystemInfoSync().pixelRatio; if (pixelRatio === 1) { return "image@1x.png"; } else if (pixelRatio === 2) { return "image@2x.png"; } else if (pixelRatio === 3) { return "image@3x.png"; } else { return "image@1x.png"; } }, getImageSrcset() { return "image@2x.png 2x, image@3x.png 3x"; }, }, }; </script> ``` 这样,如果设备的像素比是 1,则会加载 image@1x.png;如果像素比是 2,则会加载 image@2x.png;如果像素比是 3,则会加载 image@3x.png。 需要注意的是,在使用像素比时,必须保证图片的实际大小与 CSS 设置的大小一致,否则会出现变形或者模糊等问题。

相关推荐

最新推荐

recommend-type

详解使用uni-app开发微信小程序之登录模块

主要介绍了详解使用uni-app开发微信小程序之登录模块,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

uni-app:从运行原理上面解决性能优化问题

Uni-App,从了解到开发,相信大家都会觉得Uni-App性能不好,其实也这是非原生的弊病。React Native、Flutter等,非原生框架,性能上都会或多或少的折损。但各个框架,都会做出性能提升建议,所以开发者在开发前,多...
recommend-type

uni-app项目本地离线android打包步骤

uni-app项目本地离线android打包步骤 uni-app很好,但按照官方的android离线打包指导并不容易很顺利完成离线打包 结合官方文档,经过反复试验、百度总算打包成功 为此特整理成word,按自己认为合适的方式把打包步骤...
recommend-type

uni-app 打包为 H5 并上传服务器

我主要是用 uni-app 来写安卓端,近日需要将程序打包为 H5 放到 web服务器 上,经过一番折腾。 配置 在开始之前,推荐你先【拷贝】一份代码,防止打包出现问题导致代码受损。 在你的项目文件中找到 manifest.json ,...
recommend-type

uni-app中使用sqlite对本地缓存下数据进行处理

都是过来人没有太多介绍,直接上代码 附(H5+ 的SQLite传送门):https://www.html5plus.org/doc/zh_cn/sqlite.html 前提: 1.App配置权限配置选中SQLite 2.自定义调试基座 1.简单操作页面 判断数据库是否打开 ...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用matlab绘制高斯色噪声情况下的频率估计CRLB,其中w(n)是零均值高斯色噪声,w(n)=0.8*w(n-1)+e(n),e(n)服从零均值方差为se的高斯分布

以下是用matlab绘制高斯色噪声情况下频率估计CRLB的代码: ```matlab % 参数设置 N = 100; % 信号长度 se = 0.5; % 噪声方差 w = zeros(N,1); % 高斯色噪声 w(1) = randn(1)*sqrt(se); for n = 2:N w(n) = 0.8*w(n-1) + randn(1)*sqrt(se); end % 计算频率估计CRLB fs = 1; % 采样频率 df = 0.01; % 频率分辨率 f = 0:df:fs/2; % 频率范围 M = length(f); CRLB = zeros(M,1); for
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。