Как использовать функцию, объявленную в js-файле, который встроен в webpack в html? - PullRequest
0 голосов
/ 28 октября 2019

Итак, я пытаюсь создать html-файл с именем index.html на основе template.html, стиль которого основан на style.css, и функцию handleClick, объявленную в index.js. Код ниже работает для стиля, но handleClick не работает. Это возможно?

Это мой webpack.config.js

const path = require('path')
const HTMLWebpackPlugin = require('html-webpack-plugin')

module.exports = {
    entry: {
        'page': './src/index.js'
    },
    output: {
        path: path.join(__dirname, '/dist'),
        filename: "[name].js"
    },
    module: {
        rules: [
            {
                test: /\.js$/,
                exclude: /node_modules/,
                use: [
                    'babel-loader'  
                ]
            },
            {
                test: /\.css$/,
                use: [
                    "style-loader",
                    "css-loader"
                ]
            }
        ]
    },
    plugins: [
        new HTMLWebpackPlugin({
            filename: 'index.html',
            template: './src/template.html'
        })
    ]
}

Это мой index.js

require('./style.css');
function handleClick(){
    alert("called from index")
}

Это мой template.html

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>My Page's Title</title>
  </head>
  <body>
    <div>This background should be blue</div>
    <button onclick="handleClick()"> click me </button>
  </body>
</html>

а это мой style.css

div {
 background-color:blue;
}

Ответы [ 2 ]

1 голос
/ 28 октября 2019

Лучший способ - добавить addEventListener к этому элементу, используя файл js. Вы можете сделать это следующим образом:

<button id="buttonWithFunction"> click me </button>

<script>
// pure js
document.getElementById('buttonWithFunction').addEventListener('click', handleClick);

//with jquery loaded
$('#buttonWithFunction').on('click',function() {
     handleClick();
})

Вам может понадобиться обернуть следующее в document.onload, чтобы это работало.

0 голосов
/ 28 октября 2019

Предложите проверить пространство имен index.js - как я и ожидаю, webpack обернет его в пространство имен. Попробуйте определить функцию в пространстве имен окна.

window.handleClick = () => console.log('Clicked');
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...