Heim >Web-Frontend >uni-app >Wie kann das Problem gelöst werden, dass Uniapp Bilder durchläuft, aber nicht herauskommt?
Als ich kürzlich ein kleines Programm mit uniapp entwickelte, stieß ich auf ein Problem: Beim Durchlaufen von Bildern konnten die Bilder nicht normal angezeigt werden. Nach einigem Erkunden und Recherchieren habe ich endlich eine Lösung gefunden und teile sie jetzt mit Ihnen.
1. Problembeschreibung
In dem kleinen Programm, das ich entwickelt habe, muss ich alle Bilder in einem Ordner durchlaufen und auf der Seite anzeigen. Zuerst habe ich die native Komponente
<template> <view> <image v-for="(item, index) in imageList" :src="item.path" :key="index"></image> </view> </template> <script> export default { data() { return { imageList: [] // 图片列表 } }, methods: { async getImageList() { const { tempFilePaths } = await uni.chooseImage({ // 从相册中选择图片 count: 9, sizeType: ['original', 'compressed'], sourceType: ['album'], }) for (let i = 0; i < tempFilePaths.length; i++) { this.imageList.push({ path: tempFilePaths[i], }) } } }, mounted() { this.getImageList() } } </script>
Dieser Code wählt einfach Bilder aus dem Album aus, indem er die Methode uni.chooseImage()
aufruft. und fügen Sie dann den ausgewählten Bildpfad in ein Array ein und zeigen Sie dann jedes Bild mit dem Befehl v-for
an. uni.chooseImage()
方法从相册中选择图片,然后将选中的图片路径放到一个数组中,再通过v-for
指令将每张图片展示出来。
可是当我运行程序时,页面上并没有显示任何图片,于是我就开始了漫长的排查之旅。
二、排查问题
1.图片路径是否正确?
首先我就想到了图片路径的问题,我使用了uniapp的调试工具进行了检查,发现路径并没有问题,而且在调试工具的预览区域中图片是可以正常显示的。
2.图片是否正确加载?
第二个问题是图片是否正确加载,因为我使用的是本地图片,所以我试图将图片上传到了服务器上,发现图片在服务器上可以正常显示,但在本地依旧无法显示。
3.与其他组件是否冲突?
我怀疑是因为我在页面中使用了其他组件与
4.使用uniapp提供的图片浏览组件是否能正常显示?
最后我想到了使用uniapp提供的图片浏览组件<uni-image-preview>
来预览图片,结果发现渲染出来的图片是可以正常显示的。
到这里为止,我还是没有找到问题的根源,但也确信了这是
三、解决方案
这时我重新阅读了uniapp官方文档关于使用
uni-app
原生组件image
在使用web
容器(包括H5
、App
)的时候是基于HTML
img
组件实现的。image
标签的src
属性,无法直接适配本地路劲,需要特殊处理:
HBuilderX
开发工具页面,将App
启动模式设置为自定义
或自定义调试
,功能 -> 运行 -> App启动模式 -> 自定义(debug)` ,然后就和浏览器一样,本地路径、网络路径均可使用。- 真机调试时,在
manifest.json
中设置app-plus
->debug
->webview
为true
。这样在真机上调试时,也可以直接使用本地路径访问。
通过这段说明,我明白了原来是因为HTML
中的img
组件,在uniapp
中不支持直接使用本地路径,而需要进行特殊处理。
于是我采用HBuilderX
开发工具页面将App
<uni-image-preview>
zu verwenden, um eine Vorschau des Bildes anzuzeigen, und stellte fest, dass das gerenderte Bild normal angezeigt werden konnte. 🎜🎜Bis jetzt habe ich die Ursache des Problems noch nicht gefunden, bin aber überzeugt, dass es sich um ein Problem mit dem 🎜🎜Durch diese Erklärung verstehe ich, dass das daran liegt, dass dasuni-app
Native Komponenteimage basiert aufHTML
, wennWeb
-Container verwendet werden (einschließlichH5
,App code>) Wird von der <code>img
-Komponente implementiert. Das Attributsrc
des Tagsimage
kann nicht direkt an den lokalen Pfad angepasst werden und erfordert eine spezielle Verarbeitung: 🎜ist
HBuilderX
Entwicklung Stellen Sie denApp
-Startmodus aufBenutzerdefiniert
oderBenutzerdefiniertes Debuggen
ein, Funktion-> Define (debug)`, dann können genau wie beim Browser sowohl lokale Pfade als auch Netzwerkpfade verwendet werden.- Beim Debuggen auf einer realen Maschine legen Sie
app-plus
inmanifest.json
fest -> webviewtrue
. Auf diese Weise können Sie beim Debuggen auf einem realen Computer auch direkt über den lokalen Pfad zugreifen.
img
-Komponente in HTML
verwendet. Die direkte Verwendung lokaler Pfade wird in uniapp
nicht unterstützt und eine spezielle Verarbeitung ist erforderlich. 🎜🎜Also habe ich die HBuilderX
-Entwicklungstoolseite verwendet, um den App
-Startmodus auf „Benutzerdefiniert“ (Debug) zu setzen, und jetzt können die Bilder normal angezeigt werden. 🎜<template> <view> <image v-for="(item, index) in imageList" :src="'/' + item.path" :key="index"></image> </view> </template> <script> export default { data() { return { imageList: [] // 图片列表 } }, methods: { async getImageList() { const { tempFilePaths } = await uni.chooseImage({ // 从相册中选择图片 count: 9, sizeType: ['original', 'compressed'], sourceType: ['album'], }) for (let i = 0; i < tempFilePaths.length; i++) { this.imageList.push({ path: tempFilePaths[i], }) } } }, mounted() { this.getImageList() } } </script>🎜Nach dieser Untersuchung habe ich endlich verstanden, warum das
Das obige ist der detaillierte Inhalt vonWie kann das Problem gelöst werden, dass Uniapp Bilder durchläuft, aber nicht herauskommt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!