时间:2021-05-18
背景
由于小程序包大小限制,我们一般都会将icon存放到cdn上。现在的开发流程需要在开发测试环境下图片使用开发域名,线上使用生产域名。
问题重现
在小程序onLaunch的时候读取配置文件获取当前环境,并得到开发环境图片域名:
./app.js
在页面中:./pages/index/index.js
./pages/index/index.wxml
图片渲染出来了,但是在开发者工具中有报错
VM1334:1 Failed to load local image resource /4jZ1L1qECEOsikW2JKsyHQ==/109951164304393164.jpg
the server responded with a status of 500 (HTTP/1.1 500 Internal Server Error)
手机预览就看不到图片。。。
分析
看一下报错信息,说本地不存在/4jZ1L1qECEOsikW2JKsyHQ==/109951164304393164.jpg这个文件。 也就是说页面在执行onLoad之前就已经渲染了,这个时候imgHost值为空字符串,image的src拿到的图片链接就是/4jZ1L1qECEOsikW2JKsyHQ==/109951164304393164.jpg,image标签就以为这是本地图片导致的。
修复
当然修复的方法有很多,
可以将imgHost在初始化的时候就赋值:
const app = getApp()Page({ data: { imgHost: app.globalData.imageHost }, onLoad: function () { }})也可以在标签中做判断
<image src="{{imgHost ? imgHost + '/4jZ1L1qECEOsikW2JKsyHQ==/109951164304393164.jpg' : ''}}" mode="aspectFit"></image>更多尝试
之前都是渲染网络图片,如果读取本地图片更换不同文件夹中的同名图片呢?发现也是如此。
如果图片链接里有多个变量,就建议在wxs文件中写一个方法来配置图片
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1、先熟悉两个特殊的设备:(1)/dev/null:回收站、无底洞。(2)/dev/zero:产生字符。2、测试磁盘写能力复制代码代码如下:timeddif=/
Windows操作系统给人的感觉就像无底洞一样,虽然安装要求上仅需16GB的磁盘空间,但装完后使用一段时间就不是那么回事了,总是在不断蚕食我们的硬盘。喏,小编的
那个烧钱多,无底洞.建议你有毅力就手工去给人发私信推广.受不了的话考虑买一款推广向的软件吧.我用的易推微博助手功能比较全面,有小号可以自动去发评论发转发和评论相
那个烧钱多,无底洞.建议你有毅力就手工去给人发私信推广.受不了的话考虑买一款推广向的软件吧.我用的易推微博助手功能比较全面,有小号可以自动去发评论发转发和评论相
在我们辛苦策划好一个网站并且正式上线的时候,最大的期待就是网站能够被百度等搜索引擎迅速的收录,这样我们的网站才有不断增加排名的机会,否则永远都会在无底洞中,