2

Bootstrap の使い方を学んでいると、サムネイルの画像ソースに奇妙なマークアップが含まれていることに気付きました (少なくとも、私には奇妙です)。

<img data-src="holder.js/260x120" alt="260x120" style="width: 260px; height: 120px;" src="">

ここで何が起こっているのですか?なぜこれが行われているのですか? 画像は何らかの形で base64 のある時点でローカル ストレージに保存されていますか?

明確にするために、私はそのsrc="image:/部分について尋ねています。

4

2 に答える 2

5

表示されているのは、HTML5 の data-attributeではなく、data URI スキームです。ウィキペディアを引用するには:

データ URI スキームは、データを外部リソースであるかのように Web ページにインラインで含める方法を提供します。通常、この手法を使用すると、イメージやスタイル シートなどの個別の要素を、複数の HTTP リクエストではなく 1 つの HTTP リクエストで取得できるため、より効率的です。

表示されているのは、base64 でエンコードされた画像データ (この場合は PNG) です。ブラウザーはこれを確認すると、指示に従ってデータをデコードし、外部リソースであるかのように表示します。

この画像のサイズを考えると、Bootstrap の作成者は、画像を個別に保持するよりも、このようにインライン化する方が効率的であると考えています。別々に保存していた場合、画像をロードするために追加の HTTP リクエストが必要になり、ページの合計ロード時間が長くなります。

于 2013-01-04T23:29:24.857 に答える
0

Bootstrap の場合、src 属性に入るデータを生成するために Javascript が使用されていると思います。

生のソース (インスペクターのソースではない) を見ると、おそらく src 属性は表示されず、data-src のみが表示されます。

data-src 属性は、src に入れるデータを生成するために holder.js スクリプトを使用するための JavaScript への命令です。

したがって、 holder.js は画像を生成し、他の回答で説明されているように、データ uri として img にロードされます。

于 2013-12-21T15:30:58.403 に答える