Сайт Webpack не отображает мои динамически добавленные изображения на Netlify, но делает это на dev-сервере - PullRequest
1 голос
/ 01 апреля 2020

, так что для меня это первый проект, для которого я буду использовать Webpack, я проделал весь этот путь, устраняя неисправности и копируя коды в документах. В разделе hero моего проекта изображения были добавлены динамически (через javascript) , Вот код

// Import multiple images

function importAll(r) {
    let images = {};
    r.keys().map(item => { images[item.replace('./', '')] = r(item) })
    return images;
}

const images = importAll(require.context("./img/hero", true, /\.(png|jpe?g|svg)$/));

Он помещен в индекс. html и требуется в файле hero- js таким образом:

const images = require('./index');

И реализован с использованием этого кода:


// Set dynamic background
function setBg() {
    console.log(' I am Working')
    let today = new Date()
    // let today = new Date(),
    hour = today.getHours();


    // Randomize bg
    // morning
    let morningArray = ['sunset-view-of-mountains-733100.jpg', 'purple-petal-flower-surrounded-by-green-plants-during-66288.jpg', 'time-lapse-photography-of-waterfalls-during-sunset-210186.jpg', 'two-cargo-ships-sailing-near-city-2144905.jpg'];
    let morningBg = morningArray[Math.floor(Math.random() * morningArray.length)];
    let morningPath = '../src/img/hero/';
    let morning = morningPath + morningBg
    console.log(morning)
    // afternoon
    let afternoonArray = ['empty-dining-tables-and-chairs-1579739.jpg', 'brown-and-green-mountain-view-photo-842711.jpg', 'photo-of-keyboard-near-mouse-3184460.jpg', 'america-arid-bushes-california-221148.jpg'];
    let afternoonBg = afternoonArray[Math.floor(Math.random() * afternoonArray.length)];
    let afternoonPath = '../src/img/hero/';
    let afternoon = afternoonPath + afternoonBg;

    // evening
    let eveningArray = ['twisted-building-during-nighttime-1470405  s.jpg', 'beautiful-beauty-blue-bright-414612.jpg', 'landscape-photo-of-mountain-with-polar-lights-1434608.jpg', 'photo-of-toronto-cityscape-at-night-2478248.jpg'];
    let eveningBg = eveningArray[Math.floor(Math.random() * eveningArray.length)];
    let eveningPath = './src/img/hero/';
    let evening = eveningPath + eveningBg;


    // Show bg
    //morning
    if (hour < 12) {
        hero.style.background = `url(${morning}) no-repeat center center / cover`;
        greetingJs.textContent = 'Hi Good Morning,'

        // afternoon

    } else if (hour < 18) {
        hero.style.background = `url(${afternoon}) no-repeat center center / cover`;
        greetingJs.textContent = 'Hi Good Afternoon,'
    }

    // evening and night
    else {
        hero.style.background = `url(${evening}) no-repeat center center / cover`;
        greetingJs.textContent = 'Hi Good Evening,'
    }
}

На Netlify эти изображения не появляются, только запасной вариант bg-color спасает день.

После бесконечного устранения неполадок я понимаю, что некоторые интересные вещи происходят на вкладках сети chrome dev tools: enter image description here

Изображение запрошено в неправильном формате и указывает на nav. js, который не имеет к этому никакого отношения (его коды находятся в index. js и dynamicHero. js). Также: enter image description here

Ошибка, по-видимому, вызвана строкой в ​​файле nav. js, которая в остальном работает нормально. Также я заметил, что иногда изображения даже не запрашиваются, поэтому ошибки не обнаруживаются. Я также немного изменил настройки сборки netlify (а затем он начал запрашивать его) enter image description here Сначала каталог Base был пуст, а каталог Publi sh был просто dist.

Наконец, моя структура проекта выглядит следующим образом enter image description here И моя конфигурация веб-пакета:

//require plugins
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
// const MiniCssExtractPlugin = require('mini-css-extract-plugin');
// const { CleanWebpackPlugin } = require('clean-webpack-plugin');

// modules
module.exports = {
    mode: 'development',
    entry: {
        app: './src/index.js',
    },
    devServer: {

    },
    module: {
        rules: [
            // babel 
            {
                test: /\.js$/,
                exclude: /node_modules/,
                use: 'babel-loader'
            },
            {
                test: /\.html$/,
                use: [
                    {
                        // load with html loader and then minimize
                        loader: 'html-loader',
                        options: {
                            attrs: ['img:src', 'link:href'],
                            minimize: true,
                            interpolate: true,
                        }
                    }
                ]
            },
            {
                test: /\.css$/,
                use: ['style-loader', 'css-loader']
            },
            {
                test: /\.(png|svg|jpg|gif)$/,
                use: [
                    {
                        loader: 'file-loader',
                        options: {
                            esModule: false,
                        },
                    }
                ],
            },
        ]
    },
    plugins: [
        /*   new CleanWebpackPlugin({
              cleanAfterEveryBuildPatterns: ['dist']
          }), */
        new HtmlWebpackPlugin({
            template: './src/index.html',
            filename: './index.html',
        }),
        /*  new MiniCssExtractPlugin({
             filename: '[name].css',
             chunkFilename: '[id].css',
             ignoreOrder: false,
         }) */
    ],
    optimization: {
        splitChunks: {
            chunks: 'all',
        },

    },
    output: {
        filename: '[name].bundle.js',
        path: path.join(__dirname, 'dist'),
        publicPath: '/'

    },
}

Вот ссылка на мой последний предварительный просмотр развертывания на netlify: netlify

И ссылка на мой репозиторий, на случай, если вы захотите его воспроизвести: github

Что я делаю не так?

...