RN画像成分このケースを処理する特定の静的メソッド:https://facebook.github.io/react-native/docs/image.html#prefetch
注:プロミス以下
を返しImage.prefetch
はせずに、ネイティブルータフラックス(RNRF)と反応用いてこれを実現する方法の例でありますReduxのを使用して:あなたは正常に行うと画像をyからフェッチされるように
let urlOfImages = [https://...]
let preFetchTasks = [];
urlOfImages.forEach((p)=>{
preFetchTasks.push(Image.prefetch(p));
});
Promise.all(preFetchTasks).then((results)=>{
let downloadedAll = true;
results.forEach((result)=>{
if(!result){
//error occurred downloading a pic
downloadedAll = false;
}
})
if(downloadedAll){
Actions.someScene({ downloadedPics: urlOfImages})
}
})
はその後、あなたのsomeSceneコンポーネントで画像コンポーネントを使用しますいうし、リモートで私たちのローカルディスクキャッシュ:
<Image style={...} source={{uri: this.props.urlOfImages[0]}} />
また、ちょうどあなたがセキュアなHTTPSエンドポイントではなく、HTTPからイメージをロードしようとすると、あなたが問題を持っています注意してください:https://github.com/facebook/react-native/issues/8520
あなたがそれを使用したい場合Reduxは上記のコードをアクションに入れ、あなたのレデューサーがアクションに応答し、アプリケーションの要件に従って新しい状態を設定するようにします。
大変ありがとうございます。 –
私が考えている唯一のことは、これを動的に行う方法です。異なるURLから写真をロードする同じコンポーネントの3つのインスタンスがあると言うと、別の小道具を渡すことができます。動的にするのは難しい –
私はあなたが動的に何を意味するのか分かりません。また、私が元の質問に答えた場合は、その答えを受け入れてください。ありがとう。 –