2017-11-15 11 views
0

Vue javascript内の画像のような静的資産を参照するための正しいURLを探しています。vue javascript内の静的資産を参照する方法

例えば、私はカスタムアイコンイメージを使用したリーフレットマーカーを作成しています、と私はいくつかのURLを試してみたが、彼らはすべて404 (Not Found)を返す:

Main.vue:

var icon = L.icon({ 
    iconUrl: './assets/img.png', 
    iconSize:  [25, 25], 
    iconAnchor: [12, 12] 
}); 

私は、アセットフォルダと静的フォルダに画像を入れようとしましたが、運が悪いです。これらのイメージをどうにか読み込むようにvueに指示する必要がありますか?

+0

webpack?これは通常、イメージが含まれているかどうかを知りたいので、イメージがバンドルされます。イメージがサーバーに展開されている限り、バンドルシステムはおそらく気にしません。 – akatakritos

答えて

0

どのようなシステムをお使いですか? Webpack? Vue-loader?

私だけ.PNGはJavaScriptファイルではありませんので、あなたがそれらを処理するために、ファイル・ローダーまたはURLローダを使用するようにWebPACKのを設定する必要があります...ここ

をブレーンストーミングます。 vue-cliで足場を張ったプロジェクトもこれを設定しました。

あなたはそれがうまく

... 
    { 
     test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, 
     loader: 'url-loader', 
     options: { 
      limit: 10000, 
      name: utils.assetsPath('img/[name].[hash:7].[ext]') 
     } 
     }, 
... 

/assetsのように構成されていますかどうかを確認するために、webpack.conf.jsを見てみることができます束ねる時にWebPACKのことで、ハンドルされているファイルのためのものです - そのために、彼らはあなたのどこかで参照する必要がありますJavaScriptコード。

/staticに他のアセットを入れることができますが、このフォルダの内容は現状のままで/distにコピーされます。

私は変更しようとすることをお勧めいたします:

iconUrl: './dist/img.png'

iconUrl: './assets/img.png'

あなたがここに公式ドキュメントを読むことができます:https://vue-loader.vuejs.org/en/configurations/asset-url.html

は、それはあなたにお役に立てば幸い!

+0

私はどのシステムを使用しているのか、手動で追加する必要があるのか​​よくわかりません。私は./dist urlとno luckを試した – JBaczuk

0

Vueの通常の設定では、/assetsは配信されません。

画像はsrc="...YII="文字列になります。 require()

require('../assets.myImage.png')を使用して、JSコードから画像を取得するには:JavaScriptの内から使用


。パスは相対パスでなければなりません(下記参照)。

だからあなたのコードは次のようになります。必要であれば

- src 
    +- assets 
    - myImage.png 
    +- components 
    - MyComponent.vue 

var icon = L.icon({ 
    iconUrl: require('./assets/img.png'), // was iconUrl: './assets/img.png', 
    // ... 
}); 


使用相対パス

たとえば、次のようなフォルダ構造を持っていると言いますMyComponent.vueの画像を参照するには、パスはアクションでそれを示す../assets/myImage.png


ここだa DEMO CODESANDBOXなります。

関連する問題