J'utilise es6 et je souhaite importer une image à utiliser avec webpack. En regardant le doc du chargeur de fichiers , voici l'exemple qu'ils ont donné:
var url = require("file!./file.png");
l'url retournera maintenant quelque chose comme /static/351f9446b3ba577b6a79e373e074d200.png
Cela fonctionne avec require, mais comment utiliser import
pour ce faire, j'ai essayé -
import * as url from '../images/151.png';
mais cela ne fonctionne pas car l'URL reste indéfinie. Comment définir une variable sur ce que j'importe quand c'est une image?
importer * comme URL depuis '../images/151.png';
mais cela ne fonctionne pas car l'URL reste indéfinie. Comment définir une variable sur ce que j'importe quand c'est une image?
Utilisation de Webpack 2.0 avec le chargeur de fichiers branché. Cela fonctionne dans mon cas, mais l'importation renvoie quelque chose comme le bytemap d'objet au lieu de la chaîne data-uri;
Et cet objet a la propriété 'default', qui contient les mêmes données, comme si c'était nécessaire.
Honnêtement, je ne sais pas quel est cet objet, et pourquoi il y a la propriété par défaut mais c'est comme ça que je l'ai fait fonctionner.
import '../css/bootstrap.css';
import '../css/app.scss';
import * as url from '../images/webpack_logo.png';
let img = document.createElement('img');
img.style = {
height: '25%',
width: '25'
};
debugger;
img.src = url.default;
console.log('imported', url);
document.getElementById('img_container').appendChild(img);
La manière mentionnée dans la réponse précédente a renvoyé undefined, btw. Et c'est attendu, car cette syntaxe repose sur l'exportation par défaut pour être déclarée sur le module source.
Utilisation
import url from "file!./file.png"
En utilisant file-loader vous pouvez y parvenir avec la syntaxe Nice et simple de:
import youNameIt from "../images/151.png";
Peut-être peut-être utile de stocker sur une classe en tant que base64 (pas de plugins et pas de problèmes pour le localiser):
export class Images {
static img151() {return "";}
static img152() {return "";}
}
Et alors:
import {Images} from "./Images";
// code
let img = new Image();
img.src = Images.img151();