html5 调用不了函数,【前端】webpack打包后,module模块中的函数无法在html标签的事件中调用?...

折腾了好久,求大佬指点~~最近才开始接触webpack以及ES6的module,可能理解的有问题吧。。。希望大佬来指点一下我这个菜鸟。

我的想法是在一个module中定义函数,在HTML的中用onclick事件调用这个函数。

module模块代码:

— base.js —

export default {

msg: 'Hello World!',

objClick: function() {

console.log('Obj.clickFunction');

return 'Obj.clickFunction';

}

}

webpack的entry文件:

— home.js —

import base from './base.js';

function myFunction() {

let objClickVal = base.objClick();

console.log('objClickVal:', objClickVal);

return ;

}

console.log('base.msg:', base.msg);

console.log('base.objClick:', base.objClick);

webpack配置:

module.exports = {

entry: {

home: './js/home.js',

},

output: {

filename: '[name].bundle.js',

path: __dirname + '/dist',

}

}

home页面

部分:

— home.html —

ObjClick

Base.ObjClick

npm运行webpack打包后,控制台显示:

base.msg: Hello World! home.bundle.js:124

base.objClick: ƒ () { home.bundle.js:126

console.log('Obj.clickFunction');

return 'Obj.clickFunction';

}

base.msg、base.objClick都显示出来了,证明module已经成功导入进来了,但是在点击button的时候显示:

Uncaught ReferenceError: myFunction is not defined

at HTMLButtonElement.onclick (home.html:18)

onclick @ home.html:18

Uncaught ReferenceError: base is not defined

at HTMLButtonElement.onclick (home.html:19)

onclick @ home.html:19

onclick无论是直接调用base对象里的函数,还是调用home.js里定义的函数,都显示未定义。。。究竟该怎么实现呢???

回答

module中定义的函数不是全局的,改用事件监听

在window 写下一个全局函数

this.hanshu = function(){

return "hanshu!";

}

然后在你的html 标签内加上

οnclick=”hanshu()”;

即可。

今天遇到同样的问题,为了后端好绑,自己写个函数让他们调用去吧,我可不想闲着再命名了…哈哈哈

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值