日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

javascript - webpack 使用babel轉es6的時候出現了問題,但是webpack沒有報錯!!急急急

瀏覽:331日期:2023-09-12 09:36:04

問題描述

文件結構:javascript - webpack 使用babel轉es6的時候出現了問題,但是webpack沒有報錯!!急急急

/ 2017-04-13 webpack_Demo /

var webpack = require(’webpack’); var path = require(’path’); var glob = require(’glob’); var HtmlWebpackPlugin = require(’html-webpack-plugin’); var Merge = require(’webpack-merge’); var ExtractTextPlugin = require(’extract-text-webpack-plugin’); var public_PATHS = {node_modules_Path: path.resolve(’./node_modules’),public_resource_Path: path.resolve(process.cwd(), ’./src/public_resource’),vendor_Path: path.resolve(process.cwd(), ’./src/vendor’) };var file_js = getEntry(’./src/pages/**/*.js’,’./src/pages/’); var file_styles = getEntry(’./src/pages/**/*.?(css|less)’,’./src/pages/’); var file_html = getEntry(’./src/pages/**/*.html’,’./src/pages/’); var pages = Object.keys(file_html); //get file_html keyval //console.log(pages); var common_js =getEntry(’./src/vendor/js/*.js’,’./src/vendor/’); var entry_config = Object.assign(file_js,{common: [ ’jquery’,’avalon’,’lodash’,’mmRouter’] }); //common console.log(entry_config);var output_config = {path: __dirname+’/build/pages’,filename: ’[name]-[hash].js’ };var module_config ={loaders: [ //css 文件使用 style-loader 和 css-loader 來處理 { test:/.css$/, loader:’style-loader!css-loader’ }, //在webpack的module部分的loaders里進行配置即可 { test: /.js$/,exclude: [ path.resolve(__dirname, ’./src/pages’), path.resolve(__dirname, ’./node_modules’) ],include:path.resolve(__dirname, ’./src/pages’),loader: ’babel’,query: {presets: [’es2015’]} }] }var plugins_config = [//warming: this is a Array multips pages web_application need to push htmlwebpackplugin_config_Arraynew webpack.ProvidePlugin({ $: ’jquery’, jQuery: ’jquery’, ’window.jQuery’: ’jquery’, ’window.$’: ’jquery’, }), new webpack.optimize.CommonsChunkPlugin({ name: ’common’, filename: './common/common.js'}),//new ExtractTextPlugin('avalon_demo.css'), ];pages.forEach(function(pathname) {var conf = { filename: __dirname+’/build/pages/’ + pathname + ’.html’, //生成的html存放路徑,相對于path template: path.resolve(__dirname, ’./src/pages/’ + pathname + ’.html’), //html模板路徑 //path.resolve(process.cwd(), ’./src/page’), inject: ’head’, chunks:{ } };plugins_config.push(new HtmlWebpackPlugin(conf)); }); var resolve_config = {extensions: [’.js’, ’.css’, ’.less’, ’.ejs’, ’.png’, ’.jpg’,’.gif’,’.html’], //自動擴展文件后綴名,意味著我們require模塊可以省略不寫后綴名alias: { jquery: path.join(public_PATHS.vendor_Path, 'js/jquery-1.10.2.min.js'), avalon: path.join(public_PATHS.vendor_Path, 'js/avalon.js'), mmRouter: path.join(public_PATHS.vendor_Path, 'js/mmRouter.js'), lodash: path.join(public_PATHS.vendor_Path, 'js/lodash.min.js') } //模塊別名定義,方便后續直接引用別名,無須多寫長長的地址 //root:public_PATHS };var webpack_config = {entry:entry_config,output: output_config,module:module_config,plugins:plugins_config,resolve:resolve_config }; module.exports = webpack_config;//common function///** * 獲得路徑 * @param globPath: str * @param pathDir: str 對比路徑 * @returns obj */ function getEntry(globPath, pathDir) {//get from github code var files = glob.sync(globPath);var entries = {}, entry,//文件 dirname, // basename, //文件名 pathname, // extname; //文件擴展名 for (var i = 0; i < files.length; i++) { entry = files[i]; dirname = path.dirname(entry); //返回路徑中代表文件夾的部分 //console.log('dirname返回路徑中代表文件夾的部分:==>'+dirname); extname = path.extname(entry); //返回路徑中文件的后綴名,即路徑中最后一個’.’之后的部分。如果一個路徑中并不包含’.’或該路徑只包含一個’.’ 且這個’.’為路徑的第一個字符,則此命令返回空字符串。 //console.log('extname返回路徑中文件的后綴名:==>'+extname); basename = path.basename(entry, extname); //返回路徑中的最后一部分 //console.log('basename返回路徑中的最后一部分:==>'+basename); pathname = path.normalize(path.join(dirname, basename)); //規范化路徑 //console.log('pathname規范化路徑:==>'+pathname); pathDir = path.normalize(pathDir); //規范化路徑 //console.log('pathDir規范化路徑:==>'+pathDir); if(pathname.startsWith(pathDir)){pathname = pathname.substring(pathDir.length);//console.log('pathname判斷后:==>'+pathname); }; entries[pathname] = ’./’ + entry;}//console.log(entries);return entries; } /* build dev-server */var npm_run_type = process.env.npm_lifecycle_event; //get npm run type string //console.log('npm_run_type==>'+npm_run_type);var debug, // is debugdevServer, // is hrm modeminimize; // is minimizeif (npm_run_type == 'build') { // online mode (線上模式)debug = false, devServer = false,minimize = true; }else if (npm_run_type == 'build-dev') { // dev mode (開發模式)debug = true,devServer = false,minimize = false; } else if (npm_run_type == 'dev-hrm') { // dev HRM mode (熱更新模式)debug = true,devServer = true,minimize = false; }; /* * Hrm setting * (開啟熱更新,并自動打開瀏覽器) * */ if (devServer) {console.log('port:'+devServer);var webpackHot=’webpack/hot/dev-server’;config = Merge( config, {plugins: [ // Enable multi-pass compilation for enhanced performance // in larger projects. Good default. new webpack.HotModuleReplacementPlugin({multiStep: true })],devServer: { contentBase: __dirname+’/src/’, // Enable history API fallback so HTML5 History API based // routing works. This is a good default that will come // in handy in more complicated setups. historyApiFallback: true,// Unlike the cli flag, this doesn’t set // HotModuleReplacementPlugin! hot: true, inline: true,// Display only errors to reduce the amount of output. stats: ’errors-only’,host: pkg.configs.devHost, port: pkg.configs.devPort } }); }//avalon_demo.js import ’./avalon_demo.css’; import username from ’./moudle.js’; console.log(username);//moudle.js import ’babel-polyfill’; export default username='stringtest';

json

{ 'name': 'webpack_demo', 'version': '1.0.0', 'description': '', 'main': 'index.js', 'scripts': { 'test': 'echo 'Error: no test specified' && exit 1', 'start': 'webpack' }, 'author': '', 'license': 'ISC', 'devDependencies': { 'babel-cli': '^6.24.1', 'babel-core': '^6.24.1', 'babel-loader': '^6.4.1', 'babel-polyfill': '^6.23.0', 'babel-preset-env': '^1.4.0', 'babel-preset-es2015': '^6.24.1', 'css-loader': '^0.28.0', 'ejs-loader': '^0.3.0', 'extract-text-webpack-plugin': '^2.1.0', 'file-loader': '^0.11.1', 'glob': '^7.1.1', 'html-loader': '^0.4.5', 'html-webpack-plugin': '^2.28.0', 'image-webpack-loader': '^3.3.0', 'jsx-loader': '^0.13.2', 'postcss-loader': '^1.3.3', 'style-loader': '^0.16.1', 'webpack': '^2.4.1', 'webpack-merge': '^4.1.0' }}

問題說明 :項目為多入口多輸出的應用 ,獨立合并了jquery,avalon等插件為common.js,其他單獨輸出,現在需要babel:es6--轉es5,但是轉完之后沒有報錯 但是瀏覽器不能渲染。moudle的代碼被混在了common中, 整個demo chrome 不能解析

現在情況是,我的期望是jQuery四個文件獨立為common,但是我在avalon_demo.js中import其他文件moudle.js,按我的想法生成后可能會把moudle和avalon_demo打包,而實際情況是moudle的代碼在common中,在瀏覽器中找不到export的值。我不知道哪里出了問題,哪位大哥大姐能幫幫忙啊。我在這測了好幾個小時了

問題解答

回答1:

path.resolve(__dirname, ’./src/pages’)這個又exclude又include是干啥? 沒提供依賴無法具體幫你測試原因,不過可以試試用babel-preset-env替代babel-preset-es2015,最好弄個.babelrc放在外面寫babel的配置項

回答2:

new webpack.optimize.CommonsChunkPlugin({name: ’common’,filename: './common/common.js',minChunks: Infinity //僅僅創建公共組件塊,不會把任何modules打包進去。并且提供function,以便于自定義邏輯。 })

問題解決 就是添加了minChunks: Infinity 參數 ,和babel配置沒關系,問的題目有一點問題,我把網上轉的api翻譯留在這把,謝謝樓上的兄弟

ptions.name or options.names(string|string[]): 公共模塊的名稱options.filename (string): 公開模塊的文件名(生成的文件名)options.minChunks (number|Infinity|function(module,count) - boolean): 為number表示需要被多少個entries依賴才會被打包到公共代碼庫;為Infinity 僅僅創建公共組件塊,不會把任何modules打包進去。并且提供function,以便于自定義邏輯。options.chunks(string[]):只對該chunks中的代碼進行提取。options.children(boolean):如果為true,那么公共組件的所有子依賴都將被選擇進來options.async(boolean|string):如果為true,將創建一個 option.name的子chunks(options.chunks的同級chunks) 異步common chunkoptions.minSize(number):所有公共module的size 要大于number,才會創建common chunk

轉自:http://www.cnblogs.com/sloong...

標簽: JavaScript
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
蜜臀av一区二区三区| 伊人精品视频| 日韩av一级片| 日本综合视频| 日韩精品国产欧美| 国产成人精品福利| 国产日产一区| 国产福利一区二区三区在线播放| 国产探花在线精品| 欧美一区网站| 国产精品三级| 激情久久99| 日韩一区欧美| 欧美成人亚洲| 中文字幕一区二区精品区| 少妇精品久久久| 国产日韩视频| 四虎成人av| 今天的高清视频免费播放成人| 亚洲欧美日韩高清在线| 视频一区国产视频| 久久成人一区| 国产日韩欧美三区| 亚洲天堂资源| 夜久久久久久| 视频一区日韩| 免费一区二区三区在线视频| 国产精品99一区二区三| 136国产福利精品导航网址| 久久精品国产www456c0m| 久久国产精品久久久久久电车| 日本一区二区三区中文字幕| 美女av一区| 视频一区中文| 亚洲日产国产精品| 另类小说一区二区三区| 国产一区二区三区不卡av| 激情综合自拍| 日本午夜精品一区二区三区电影 | 男人操女人的视频在线观看欧美| 亚欧成人精品| 99精品视频精品精品视频| 欧美午夜网站| 国产精品毛片在线| 97se综合| 国产精品一区二区精品视频观看| 亚洲永久字幕| 中文在线а√天堂 | 亚洲精品在线a| 136国产福利精品导航网址| 国产精品天堂蜜av在线播放| 在线视频亚洲| 日韩伦理一区| 日韩国产高清在线| 国产精品人人爽人人做我的可爱| 成人自拍av| 美女精品视频在线| 91福利精品在线观看| 亚洲欧洲一区| 久久精品国产68国产精品亚洲| 老司机精品视频网| 日本精品国产| 蜜桃传媒麻豆第一区在线观看| 国产 日韩 欧美一区| 国产精品1luya在线播放| 日韩福利视频一区| 一区二区国产在线观看| 99视频精品| 欧美日韩国产一区二区三区不卡| 日韩不卡一区| 精品国产中文字幕第一页| 亚洲bt欧美bt精品777| 久色成人在线| 91高清一区| 久久久久免费av| 日韩欧美一区二区三区在线观看| av资源中文在线| 国产精久久久| 天堂俺去俺来也www久久婷婷| 午夜精品网站| 亚洲国产一区二区在线观看| 久久久蜜桃一区二区人| 亚洲一区资源| 天堂中文av在线资源库| 欧美一级鲁丝片| 久久久久久久久成人| 国产九一精品| 国产精品视频一区二区三区综合| 日韩免费精品| 亚洲精品888| 亚洲人成在线网站| 国产一区日韩| 久久xxx视频| 蜜臀va亚洲va欧美va天堂| 国产成人精选| 久久毛片亚洲| 久久av中文| 久久99高清| 国产成人精品一区二区三区视频| 色欧美自拍视频| 亚洲一级少妇| 久久久久99| 亚洲激情中文| 亚洲主播在线| 亚洲精品福利| 欧美视频一区| 精品国产18久久久久久二百| 高清一区二区三区av| 国产成人精选| 成人亚洲精品| 久久国产主播| 欧美高清一区| 丝袜美腿成人在线| 免费人成黄页网站在线一区二区| 乱人伦精品视频在线观看| 蜜臀久久久99精品久久久久久| 免费看的黄色欧美网站| 亚洲欧洲专区| 国产日韩欧美三区| 精品国产网站| 久久蜜桃av| 视频精品一区二区| 日韩福利在线观看| 国产一区二区三区四区二区| 精品国产一区二区三区噜噜噜| 欧美一区久久久| 国产亚洲网站| 欧美日韩va| 成人精品视频| 欧美va天堂| 日韩精品欧美成人高清一区二区| 国产精品网站在线看| 欧美三级精品| 亚洲综合中文| 久久免费精品| 欧美色图一区| 午夜视频一区二区在线观看| 精品久久99| 亚洲欧美综合| 日韩精品欧美成人高清一区二区| 日韩av自拍| 性色一区二区| 免费视频一区二区三区在线观看| 欧美午夜精彩| 日韩av中文字幕一区二区三区| av中文资源在线资源免费观看| 中文一区在线| 久久gogo国模啪啪裸体| 久久久夜夜夜| 国产日韩欧美一区| 91精品久久久久久久久久不卡| 日韩一区免费| 中文字幕在线高清| 亚洲三级网址| 欧美黄色一区| 婷婷激情图片久久| 国产精品视频一区视频二区| 免费视频一区三区| 国产精品一区二区av日韩在线| 99久久www免费| 国产精品一区二区av交换| 欧美1级日本1级| 国产精品调教视频| 亚洲免费一区二区| 欧美激情国产在线| 香蕉久久一区| 欧美成人日韩| 麻豆精品蜜桃视频网站| 鲁大师影院一区二区三区| 欧美日韩夜夜| 亚洲一区黄色| av中文字幕在线观看第一页| 亚洲免费一区三区| 影视先锋久久| 精品三级国产| 日韩一区二区三区精品| 在线日韩av| 精品国产乱码久久久久久1区2匹| 日韩在线a电影| av亚洲一区二区三区| 国产三级精品三级在线观看国产| 99热精品在线| 午夜av成人| 久久国产精品免费一区二区三区| 欧美亚洲国产精品久久| 黄色精品视频| 国产日韩欧美一区二区三区在线观看| 日本免费久久| 里番精品3d一二三区| 日本不卡一二三区黄网| 欧美影院三区| 精品成av人一区二区三区 | 日韩在线观看一区二区三区| 久久国产直播| 色婷婷色综合| 国产精品高清一区二区| 美国三级日本三级久久99 | 亚洲欧美一级| 婷婷综合网站| 丁香六月综合|