首页 > 编程语言 >#yyds干货盘点#【愚公系列】2022年12月 微信小程序-图片加载和全屏适配问题

#yyds干货盘点#【愚公系列】2022年12月 微信小程序-图片加载和全屏适配问题

时间:2022-12-14 22:31:45浏览次数:133  
标签:yyds 显示 12 缩放 适配 裁剪 模式 图片 加载

前言

在使用图片问题中可能会遇到各种各样的问题,比如图片加载不出来,图片显示在不同机型效果不同,图片加载展示问题等等。

微信小程序image相关属性如下:

属性 类型 默认值 必填 说明 最低版本
src string 图片资源地址 1.0.0
mode string scaleToFill 图片裁剪、缩放的模式 1.0.0
webp boolean false 默认不解析 webP 格式,只支持网络资源 2.9.0
lazy-load boolean false 图片懒加载,在即将进入一定范围(上下三屏)时才开始加载 1.5.0
show-menu-by-longpress boolean false 长按图片显示发送给朋友、收藏、保存图片、搜一搜、打开名片/前往群聊/打开小程序(若图片中包含对应二维码或小程序码)的菜单。 2.7.0
binderror eventhandle 当错误发生时触发,event.detail = {errMsg} 1.0.0
bindload eventhandle 当图片载入完毕时触发,event.detail = {height, width} 1.0.0

mode明细属性:

合法值 说明
scaleToFill 缩放模式,不保持纵横比缩放图片,使图片的宽高完全拉伸至填满 image 元素
aspectFit 缩放模式,保持纵横比缩放图片,使图片的长边能完全显示出来。也就是说,可以完整地将图片显示出来。
aspectFill 缩放模式,保持纵横比缩放图片,只保证图片的短边能完全显示出来。也就是说,图片通常只在水平或垂直方向是完整的,另一个方向将会发生截取。
widthFix 缩放模式,宽度不变,高度自动变化,保持原图宽高比不变
heightFix 缩放模式,高度不变,宽度自动变化,保持原图宽高比不变
top 裁剪模式,不缩放图片,只显示图片的顶部区域
bottom 裁剪模式,不缩放图片,只显示图片的底部区域
center 裁剪模式,不缩放图片,只显示图片的中间区域
left 裁剪模式,不缩放图片,只显示图片的左边区域
right 裁剪模式,不缩放图片,只显示图片的右边区域
top left 裁剪模式,不缩放图片,只显示图片的左上边区域
top right 裁剪模式,不缩放图片,只显示图片的右上边区域
bottom left 裁剪模式,不缩放图片,只显示图片的左下边区域
bottom right 裁剪模式,不缩放图片,只显示图片的右下边区域

一、图片加载

imsge加载图片本质是使用wx.downloadFile来加载图片的。

加载不出来图片主要有以下几种情况

  • 图片格式不规范
  • 线上SSL证书有问题
  • 文件描述信息不完整
  • 服务器发生302跳转
  • 网络不好

网络不好情况可以用binderror来处理图片加载,重新给src属性赋值。

服务器发生302跳转:目前小程序已经支持image加载短链接地址图片,但直接使用downloadFile会出现资源不可用

// 直接加载短链接网址,返回403
// 403代表资源不可用
wx.downloadFile({
  url: 'http://t.cn/A622upBw',
  complete(res){
    console.log(res);
    
  }
})

二、适配机型实现全屏背景图

这个问题都是使用css去实现全屏背景图的,代码如下:

<!-- 背景图 -->
<view class="container">
</view>
/* 背景图样式 */
.container {
	position: fixed;
	width: 100%;
	height: 100%;
	background-color:azure;
	top: 0;                        
  bottom: 0;                     
  left: 0;                       
	right: 0;    
	z-index: -1;          
}
.container::after {              
  content: "";                   
  background: url(https://res.wx.qq.com/wxdoc/dist/assets/img/0.4cb08bb4.jpg) no-repeat center center;                         
  background-size: cover;        
  opacity: 0.5;                  
  top: 0;                        
  bottom: 0;                     
  left: 0;                       
  right: 0;                      
  position: absolute;            
}

在这里插入图片描述

标签:yyds,显示,12,缩放,适配,裁剪,模式,图片,加载
From: https://blog.51cto.com/u_15437432/5938436

相关文章

  • CF1284E New Year and Castle Construction
    链接:https://www.luogu.com.cn/problem/CF1284E题目描述:给定\(n\)个点,求\(4\)个点围住另外一个点\(5\)元子集个数。(保证任意三点不共线,不存在相同的点)题解:我们可以考虑......
  • 20221214每日学习
    leetcode题目:130被围绕的区域思路:1.遍历所有边界。2.如果遇到o,就开始bfs像外边延展,可以将这时候的o设置为e,然后再遍历所有的内部点,将e修改为o,将原生的o修改为x。题解:......
  • secureCRT yyds
    上一篇使用mobaxterm作为上位机,使用lrzlsz命令和开发收发文件,但是在使用中经常出现卡死,文件无法发送给开发板。后来找了其他软件SecureCRT,这是个付费软件。在知乎平台找到......
  • Oracle12C查询自建用户(非系统自带)
    selectusernamefromdba_userswhereINHERITED='NO'; SELECTusername,account_statusfromdba_userswhereaccount_status='OPEN'andusernamenotlike'%SYS......
  • 「NOIP2012」开车旅行
    「NOIP2012」开车旅行题面描述:小\(A\)与小\(B\)开车旅行,两个点的距离是两个点的高度的差的绝对值,若两个点的距离相同,则认为海拔低的要更近,小\(A\)以离他次近的点作......
  • 闲话 22.12.14
    闲话啊啊啊数数题的式子和含义怎么也对不上啊啊啊有好心人给我具体讲讲他在说啥吗?感觉最近这两天的闲话比较低质量在我啃明白这个前不是很可能高质量(对了顺便问个(可能......
  • 网络编程1.4-端口-2022-12-14
     端口表示计算机一个程序的进程。  -不同的进程有不同的端口,端口号不能重复,用来区分软件 -被规定0-65535  -TCPUDP各为65535,两个类端口号可以相同端口......
  • #yyds干货盘点#node.js链接MongoDB数据库
    在这之前确保当前环境下安装了mongodb的模块,且mongodb数据库已经启动,安装mongodb模块到当前目录可以通过yarnaddmongodb我此时安装的是v4.1.4版本的mongodb常见的连接方法......
  • 那些你不知道的炫酷开关交互效果(12种)
    本文将继续更新那些炫酷交互效果系列文章,今天带来的是有关toggle开关相关的组件。以下是本次文章涉及到的开关组件总览图,总计收集12款不同交互效果,相信总有一款适合你。......
  • #yyds干货盘点# react笔记之学习之state注意事项
    前言我是歌谣我有个兄弟巅峰的时候排名c站总榜19叫前端小歌谣曾经我花了三年的时间创作了他现在我要用五年的时间超越他今天又是接近兄弟的一天人生难免坎坷大不了从......