Итак, я пытаюсь создать 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 ответа
Лучший способ - добавить 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, чтобы это работало.
Предложите проверить пространство имен index.js - как я и ожидаю, webpack обернет его в пространство имен. Попробуйте определить функцию по пространству имен окна.
window.handleClick = () => console.log('Clicked');
Похожие вопросы
Новые вопросы
javascript
По вопросам программирования на ECMAScript (JavaScript/JS) и его различных диалектах/реализациях (кроме ActionScript). Обратите внимание, что JavaScript — это НЕ Java. Включите все теги, относящиеся к вашему вопросу: например, [node.js], [jQuery], [JSON], [ReactJS], [angular], [ember.js], [vue.js], [typescript], [стройный] и т. д.