uniapp 发布后原生img正常,image无法显示,img与uniapp image使用区别

问题描述:

需要在本地测试和发布后图片都能正常显示,线上是把项目放在了/web目录下,使用html img src="static/images/guideArrow.png"时都能正常显示,但使用uniapp image则不行,由于image兼容性比较好,所以想改成Image格式。

测试效果:

uniapp image src="static/images/guideArrow.png"在本地和服务器都是不能正常显示的,需要改成绝对路径src="/static/images/guideArrow.png"在本地才能正常显示,但是在发布到服务器后会少个/web,导致服务器显示不了图片。

img能正常显示的原因是src解析与uniapp image src不同,src开头带不带/都是代表绝对路径(相对于服务器根目录),但在uniapp image中,不带则代表相对路径(相对于当前路由目录)。img有个特点, 当使用绝对路径,服务器部署到/web时,它会在/web下找图片,但是uniapp image则不会,image使用绝对路径是直接在服务器的"/"找图片。

解决办法:

写一个url转换方法,根据不同环境加不同前缀。

复制代码
getImgUrl(url) {
   if (url) {
        return (process.env.NODE_ENV === 'production' ? '/web' : '') + url
    }
}

调用:

复制代码
<image
     :src="getImgUrl('/static/images/guideArrow.png')"
 ></image>
相关推荐
MicrosoftReactor2 小时前
技术速递|GitHub Copilot CLI 斜杠命令速查表
github·copilot·cli
wu~9703 小时前
GitHub永不遗忘,使用git push -f来覆盖的提交依旧保留
git·github
局外人LZ3 小时前
Uniapp脚手架项目搭建,uniapp+vue3+uView pro+vite+pinia+sass
前端·uni-app·sass
m0_694845573 小时前
music-website 是什么?前后端分离音乐网站部署实战
linux·运维·服务器·云计算·github
独自破碎E3 小时前
已经 Push 到远程的提交,如何修改 Commit 信息?
开发语言·github
2501_915918416 小时前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
jiang_changsheng6 小时前
工作流agent汇总分析 2
java·人工智能·git·python·机器学习·github·语音识别
前端呆头鹅6 小时前
Websocket使用方案详解(uniapp版)
websocket·网络协议·uni-app
馨谙6 小时前
Ansible 配置文件详解:让自动化管理更轻松
运维·github·ansible
浮桥6 小时前
uniapp+h5 公众号实现分享海报绘制
uni-app·notepad++