車の販売サイトでvue-routerを使用しています。vue-routerビューキャッシング/データリセットなし
私は、販売するすべての車のリストを持つインデックスページを持っており、クリックするとその特定の車両の単一のビューにリンクします。
単一のビューページに大きな「ヘッダー」イメージがあり、ページが読み込まれたときにページの高さにジャンプしないように高さが固定されたコンテナ内にあります。
この単一のビューに進むと、私はAPI呼び出しを呼び出して車両データを取得し、見出し画像をフェードインします。これを行うために
:デフォルトでは
<div class="singleVehicle__mainImage">
<span :style="styles" :class="{'imageLoaded' : mainImageLoaded }" v-if="vehicle"></span>
</div>
export default {
data() {
return {
vehicle: null,
styles: {
backgroundImage: null
},
mainImageLoaded: null
}
},
created() {
this.getVehicle().then(() => {
this.mainImageBackground();
});
},
methods: {
mainImageBackground() {
var source = "IMAGE SOURCE URL";
this.styles.backgroundImage = "url("+source+")";
var $this = this;
var img = new Image();
img.onload = function() {
$this.mainImageLoaded = true;
}
img.src = source;
if (img.complete) img.onload();
}
}
}
を、画像ラッパー内のスパンは.imageLoadedクラスが追加されたときに1に移行され、その後0不透明度としています。
これは問題なく動作しますが、各車両が初めて搭載されたときにのみ有効です。イメージはロードされるまで待ってからフェードインされます。それ以降はイメージが読み込まれるとイメージがポップアップします。imageLoadedクラスがリセットされていない/ビューを離れるときにデータがリセットされていません。
ブラウザキャッシュをクリアすると、再び動作しますが、車両ビューごとに1回動作します。
それはやっているように見えましたが、なぜ私は今のところ確信していますか? – Lovelock
あなたは、そのスパンの可視性を独立して制御している2つの同時呼び出しがあるようです。 1つは車両データがロードされ、もう1つはロードされている画像です。 v-ifを削除すると、車両のデータがロードされない可能性がありますが、イメージがロードされるとイメージがフェードインできるようになります。あなたはそれを "完全な証拠"にしたいと思ったら、私は車のデータを読み込み、それが終わったら背景のイメージを読み込みます。 – jostrander