Heim >Web-Frontend >js-Tutorial >Wie zeige ich dynamisch benannte Bilder in React Native an?

Wie zeige ich dynamisch benannte Bilder in React Native an?

Barbara Streisand
Barbara StreisandOriginal
2024-11-24 02:17:09784Durchsuche

How to Display Dynamically Named Images in React Native?

Dynamische Bildnamen in React Native: Verwenden des Image Require-Moduls

Bei der Arbeit mit React Native können Sie mit dem Image-Modul Bilder anzeigen in Ihren Bewerbungen. In der Regel können Bilder statisch mithilfe der Syntax „require('image!name-of-the-asset')“ referenziert werden.

Beim Versuch, dynamische Bildnamen zu verwenden, stellt sich jedoch häufig eine Frage. Wenn Sie beispielsweise eine dynamische Zeichenfolge haben, die einen Bildnamen darstellt, z. B. „Avatar“, funktioniert der folgende Code nicht:

<Image source={require('image!' + 'avatar')} />

Dies führt zu der Fehlermeldung „Unbekanntes Modul erforderlich „image!avatar“. "".

Erklärung

Laut der React Native-Dokumentation müssen statische Ressourcen direkt mit referenziert werden die zuvor erwähnte statische Syntax. Das dynamische Laden von Bildern wird nicht unterstützt.

// Correct:
<Image source={require('image!my-icon')} />

// Incorrect:
var icon = 'my-icon-active';
<Image source={require('image!' + icon)} />

Alternative Lösung

Wenn Sie dynamische Bildnamen verwenden müssen, können Sie die Bildelemente in einem separaten Array oder speichern Objekt und referenzieren Sie sie dann mithilfe der Quellstütze der Bildkomponente:

const images = {
  avatar: require('image!avatar'),
  logo: require('image!logo'),
};

<Image source={images[dynamicImageName]} />

Zusätzlich Hinweis

Für iOS müssen Sie daran denken, Ihre Bilder in einen Asset-Katalog in Ihrem Xcode-Projekt aufzunehmen. Dies ist notwendig, damit Bilder in Ihrer React Native-Anwendung korrekt referenziert werden.

Das obige ist der detaillierte Inhalt vonWie zeige ich dynamisch benannte Bilder in React Native an?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn