Загрузчик файлов Webpack, обслуживающий изображения, но не аудио (mp3) - PullRequest
0 голосов
/ 25 июня 2019

Я пишу приложение TypeScript, используя Webpack и загрузчик файлов для обслуживания изображений и аудио.Я не могу заставить конфигурацию веб-пакета работать с аудиофайлами.

Я получаю GET http://localhost:8080/media/d.mp3 404 (Not Found)

Изображения отлично работают на сервере dev, а также хорошо сочетаются с настройкой веб-пакета ниже.

Структура папки:

|-public    
|---audio    
|---images    
|-src    
|---audio    
|---images

Тот же результат, если я объединю все расширения в одну строку и использую одну папку.

My webpack.config.js :

const path = require('path');

module.exports = {
    entry: "./src/index.ts",
    output: {
        path: path.resolve(__dirname, 'public/scripts'),
        filename: 'bundle.js'
    },
    devtool: "source-map",
    module: {
        rules: [{
                test: /\.tsx?$/,
                loader: "awesome-typescript-loader"
            },
            {
                test: /\.js$/,
                exclude: /node_modules/,
                use: {
                    loader: "babel-loader"
                }
            },
            {
                test: /\.(scss|sass|css)$/,
                exclude: /node_modules/,
                use: ['style-loader', 'css-loader', 'sass-loader']
            },
            {
                test: /\.(png|jpe?g|gif)$/,
                use: [
                    {
                        loader: 'file-loader',
                        options: {
                            name: '[name].[ext]',                            
                            outputPath: '../images/',
                            publicPath: 'images/',
                            useRelativePaths: true
                        }
                    }
                ]
            },
            {
                test: /\.(mp3|wav)$/,
                use: [
                    {
                        loader: 'file-loader',
                        options: {                            
                            name: '[name].[ext]',                            
                            outputPath: '../audio/',
                            publicPath: 'audio/',
                            useRelativePaths: true
                        }
                    }
                ]
            },
        ]
    },
    resolve: {
        extensions: [".webpack.js", ".web.js", ".ts", ".tsx", ".js"]
    },
    devServer: {
        contentBase: path.resolve(__dirname, 'public'),
        publicPath: '/scripts/'
    },
    node: {
        fs: "empty"
    }
};
...