【问题标题】:How to Add png Images to JS using Webpack?如何使用 Webpack 将 png 图像添加到 JS?
【发布时间】:2018-09-12 04:03:59
【问题描述】:

我正在开发一款 HTML5 游戏。我正在使用一个使用 Webpack 的样板。 我一直在尝试将本地文件夹中的 png 图像添加到 js 文件中,但我不断收到以下错误:

GET http://localhost:3000/alien.png 404 (Not Found)Uncaught DOMException: Failed to execute 'drawImage' on 'CanvasRenderingContext2D': The HTMLImageElement provided is in the 'broken' state.

我在canvas.js文件中使用的代码如下:

let alienImg = new Image();
alienImg.src = 'alien.png';
c.drawImage(alienImg, 300, 300)

我是在尝试将图像放到画布上的方式上做错了什么,还是我的 webpack.config.js 文件中有什么问题?

webpack文件如下,供参考:

 module: {
        rules: [
            {
                test: /\.(js)$/,
                exclude: /(node_modules|bower_components)/,
                use: {
                    loader: 'babel-loader',
                    options: {
                        presets: ['env']
                    }
                }
            },
            {
                test: /\.html$/,
                loader: 'html-loader?attrs[]=video:src'
            }, 
            {
                test: /\.mp4$/,
                loader: 'url-loader?limit=10000&mimetype=video/mp4'
            },
            {
                test: /\.png$/,
                loader: "url-loader?mimetype=image/png" 
            }
        ]
    },

谁能帮帮我?提前谢谢!

【问题讨论】:

    标签: javascript html webpack


    【解决方案1】:

    我刚刚使用:html2Canvas

    import html2canvas from 'html2canvas';
    

    ...

    html2canvas(document.querySelector(selector)).then(canvas => {
      console.log(canvas);
      document.body.appendChild(canvas)
      canvas.setAttribute('downloads', 'nameOfImage.png')
      var image = canvas.toDataURL("image/png").replace("image/png", "image/octet-stream");
      window.location.href = image
    });
    

    我希望这可以在某种程度上有所帮助。如果是这样,快乐的日子。 :)

    【讨论】:

      【解决方案2】:

      使用时:

      alienImg.src = 'alien.png';
      

      您正在为图像提供图像的 url - 该路径可能不存在(假设它为您提供 404)。

      我认为你想要做的是

      import alienImage from './alien.png'; 
      

      然后你就可以使用了

      alienImg.src = alienImage; 
      

      这样做的目的是为您提供图像位置的正确 URL - 在 webpack 完成捆绑并公开公共资源之后。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2023-03-27
        • 1970-01-01
        • 2022-07-04
        • 2013-01-12
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2011-01-10
        相关资源
        最近更新 更多