前端模块化开发遇到的问题,zepto引入报错
直接上代码吧:
我的zepto是直接npm install zepto
的
// app.js
"use strict";
import $ from 'zepto'
let str = "ok2s"
$("p").html(str)
编译后chrome的报错:
Uncaught TypeError: Cannot read property 'createElement' of undefined
...
我用的是gulp的browserify编译的,因为实际项目中有多个入口文件,所以用了glob
// gulpfile.js
gulp.task("browserify", function () {
glob('src/js/**.main.js', function(err, files) {
if(err) done(err);
var tasks = files.map(function(entry){
return browserify({entries: [entry]})
.transform(babelify,{ //此处babel的各配置项格式与.babelrc文件相同
presets: [
'es2015' //转换es6代码
]
})
.bundle()
.pipe(source(entry))
.pipe(rename(function(path){
path.basename += '.bundle';
path.dirname = ""
}))
.pipe(gulp.dest('dist/js/main'));
});
return es.merge.apply(null, tasks);
})
});
我项目文件应该没问题,因为我用 import $ from 'jquery'
是没问题的,
求前辈指教,谢谢
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
因为zepto没有提供对CommonJS的支持,楼主可以参考这篇文章,虽然是webpack的,但是解决方案都是一个思路。
https://sebastianblade.com/ho...
图方便的话就直接用zepto-browserify
jQuery 支持 CMD, 但是 Zepto 并不支持, 所以用 jQuery 来说项目文件没问题才是最大问题.
一个办法是把 Zepto 改成支持 CMD 的, 这个办法改动原本的 Zepto 源代码, 我不是很推荐.
另外就是不要把 Zepto 打包. 本身 Zepto 也不会经常更新, 打包之后别的模块一更新, Zepto 还要被打包一遍, 徒然增加更新包的体积, 纯属浪费.