webpack处理非模块化的几方法
webpack处理非模块化文件有几方法,主要分为外链和webpack打包二种情况:
一、使用CDN外部链接的方法
官网文档External: https://webpack.github.io/docs/library-and-externals.html
如下示例是把微信的JSSDK和zepto使用外链的方法在页面上使用script引用,并导出别名
1 module.exports = { 2 entry: { 3 app: './src/main.js', 4 vendors: ['vue', 'vue-router', 'vue-touch', 'fastclick', 'moment'] 5 }, 6 output: { 7 path: path.resolve(__dirname, '../dist/static'), 8 publicPath: './static/', 9 filename: '[name].js' 10 }, 11 // CDN 12 externals: { 13 'zepto':'$', 14 'wx': 'jWeixin' 15 },
二、webpack打包在一起的方法
官网文档Shimming: https://webpack.github.io/docs/shimming-modules.html
如下示例是还是使用zepto,需要用到webpack-zepto这个模块,为了统一成import $ from 'zepto' ,使用webpack别名的配置alias指定zepto的路径。如此构建的时候会打包在build.js中
1 resolve: { 2 extensions: ['', '.js', '.vue'], 3 fallback: [path.join(__dirname, '../node_modules')], 4 alias: { 5 'src': path.resolve(__dirname, '../src'), 6 'moment': path.join(__dirname, '../node_modules/moment/min/moment-with-locales.min.js'), 7 'zepto': path.join(__dirname, '../node_modules/webpack-zepto/index.js') 8 } 9 }, 10 11 plugins: [ 12 new webpack.optimize.CommonsChunkPlugin('vendors', 'vendors.bundle.js'), 13 new webpack.ProvidePlugin({ 14 $: 'zepto', 15 Zepto: 'zepto', 16 'window.Zepto': 'zepto' 17 }) 18 ],
相关参考资料:
http://www.ituring.com.cn/article/200534
http://www.alloyteam.com/2016/01/webpack-use-optimization
https://www.npmjs.com/package/webpack-zepto