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

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

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

瀏覽:329日期: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久久,三上悠亚国产精品一区二区三区
国产一区二区三区四区五区| 日韩亚洲精品在线观看| 亚洲激情黄色| 久久成人亚洲| 欧美日韩18| 国产一区二区三区四区五区传媒| 亚洲播播91| 日韩国产欧美三级| 精品国模一区二区三区| 吉吉日韩欧美| 美女日韩在线中文字幕| 国产美女精品视频免费播放软件| 日韩欧美精品一区二区综合视频| 99日韩精品| 日韩中文字幕麻豆| 999久久久91| 久久久久国产一区二区| 日韩在线网址| 中文字幕一区二区三区四区久久 | 久久精品国内一区二区三区| 国产精品久久久久蜜臀| 爽好久久久欧美精品| 国产亚洲欧美日韩在线观看一区二区| 蜜芽一区二区三区| 久久国产免费| 久久精品一区二区三区中文字幕| 国产精品一区二区美女视频免费看 | 国产九一精品| 国产一区二区精品久| 久久久久久夜| 国产精品15p| 综合视频一区| 精品中文在线| 中文字幕日本一区二区| 精品国产一区二区三区噜噜噜| 亚洲高清毛片| 国产精品超碰| 欧美综合社区国产| 久久久久九九精品影院| 亚洲午夜一级| 亚洲成av人片一区二区密柚| 精品国产一区二区三区2021| 欧美片第1页综合| 精品久久免费| 日韩国产成人精品| 日韩欧美2区| 免费一级欧美在线观看视频| 日本成人在线视频网站| 在线观看精品| 久久精品1区| 热久久国产精品| 欧美一区久久| 国产精品午夜一区二区三区| 99在线|亚洲一区二区| 精品国产亚洲日本| 欧美日韩伊人| 2023国产精品久久久精品双| 99精品在线免费在线观看| 97欧美在线视频| 激情五月色综合国产精品| 免费av一区| 亚州av乱码久久精品蜜桃| 久久免费大视频| 欧美天堂一区| 视频一区国产视频| 91麻豆国产自产在线观看亚洲| 欧美精品自拍| 国产乱子精品一区二区在线观看 | 精品国产三区在线| 日韩三级久久| 亚洲大全视频| 在线手机中文字幕| 国产探花一区| 7m精品国产导航在线| 久久久久久美女精品| 久久不射网站| 日韩视频一区| 婷婷综合福利| 久久国产88| 伊人国产精品| 亚洲专区视频| 六月丁香综合| 久久久久久久久久久妇女| 美女毛片一区二区三区四区| 91精品国产自产精品男人的天堂| 亚洲日产国产精品| 婷婷激情一区| 91成人超碰| 美女视频网站久久| 九色精品91| 国产suv精品一区| 视频一区日韩精品| 免费一级欧美片在线观看网站| 精品国模一区二区三区| 成人高清一区| 亚洲精品日本| 欧洲av不卡| 天堂资源在线亚洲| 神马久久午夜| 韩国久久久久久| 欧美 日韩 国产一区二区在线视频| 久久婷婷一区| 岛国精品一区| 国产精品久久久久av电视剧| 日韩精品一卡二卡三卡四卡无卡| 99pao成人国产永久免费视频 | 你懂的国产精品| 久久人人精品| 99成人在线视频| 人人精品亚洲| 亚洲一区二区三区四区五区午夜| 日韩动漫一区| 精品国产精品国产偷麻豆| 亚洲精品国产嫩草在线观看 | 鲁大师成人一区二区三区| 综合激情婷婷| 久久久久午夜电影| 国产精品高颜值在线观看| 欧美xxxx性| 高清久久精品| 欧美成人综合| 黑丝一区二区三区| 日韩午夜免费| 日韩中文字幕区一区有砖一区| 亚洲综合色婷婷在线观看| 视频一区视频二区中文| 蜜臀a∨国产成人精品| 国产日本亚洲| 日韩欧美少妇| 麻豆精品新av中文字幕| 成人福利av| 蜜臀av性久久久久蜜臀aⅴ流畅| 电影天堂国产精品| 91福利精品在线观看| 日韩在线中文| 国产伦理久久久久久妇女| 亚洲国产专区| 鲁鲁在线中文| 日韩一区网站| 中文字幕成人| 亚洲成人精选| 午夜欧美精品久久久久久久| 中文字幕在线看片| 国产乱子精品一区二区在线观看| 亚洲成人va| 国产精品xxxav免费视频| 久久国产中文字幕| 亚洲精品乱码| 国产精品毛片久久| 99久久www免费| 欧美激情日韩| 天堂资源在线亚洲| 中文字幕av一区二区三区人| 成人免费一区| 久久精品 人人爱| 亚洲精品动态| 国产一区久久| 久久尤物视频| 石原莉奈在线亚洲三区| 黄色欧美日韩| 欧美激情aⅴ一区二区三区| 国产日韩欧美中文在线| 精品一区二区男人吃奶 | 欧美jjzz| 精品视频一区二区三区四区五区| 狠狠爱www人成狠狠爱综合网| 日韩激情综合| 日韩在线网址| 日韩亚洲国产欧美| 91精品一区国产高清在线gif| 最新中文字幕在线播放 | 蜜桃传媒麻豆第一区在线观看 | 亚洲精品自拍| 蜜臀久久99精品久久久久宅男| 婷婷国产精品| 国产精品中文字幕制服诱惑| 久久人人99| 风间由美中文字幕在线看视频国产欧美 | 日韩精品一页| 国产一区二区高清| 免费观看亚洲| 久久精品国产精品亚洲毛片| 蜜臀精品久久久久久蜜臀| 精品午夜久久| 国产探花一区在线观看| 性色一区二区| 日韩午夜黄色| 婷婷综合激情| 99久久精品费精品国产| 国产成人调教视频在线观看| 欧美亚洲国产日韩| 亚洲免费毛片| 免费人成精品欧美精品| 偷拍精品精品一区二区三区| 国产一区二区久久久久| 麻豆精品视频在线观看视频| 国产精一区二区| 欧美激情五月| 国产精品一区亚洲| 国产精品v一区二区三区|