成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript - webpack 使用babel轉(zhuǎn)es6的時(shí)候出現(xiàn)了問(wèn)題,但是webpack沒(méi)有報(bào)錯(cuò)!!急急急

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

問(wèn)題描述

文件結(jié)構(gòu):javascript - webpack 使用babel轉(zhuǎn)es6的時(shí)候出現(xiàn)了問(wèn)題,但是webpack沒(méi)有報(bào)錯(cuò)!!急急急

/ 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 來(lái)處理 { test:/.css$/, loader:’style-loader!css-loader’ }, //在webpack的module部分的loaders里進(jìn)行配置即可 { 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存放路徑,相對(duì)于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’], //自動(dòng)擴(kuò)展文件后綴名,意味著我們r(jià)equire模塊可以省略不寫后綴名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') } //模塊別名定義,方便后續(xù)直接引用別名,無(wú)須多寫長(zhǎng)長(zhǎng)的地址 //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 對(duì)比路徑 * @returns obj */ function getEntry(globPath, pathDir) {//get from github code var files = glob.sync(globPath);var entries = {}, entry,//文件 dirname, // basename, //文件名 pathname, // extname; //文件擴(kuò)展名 for (var i = 0; i < files.length; i++) { entry = files[i]; dirname = path.dirname(entry); //返回路徑中代表文件夾的部分 //console.log('dirname返回路徑中代表文件夾的部分:==>'+dirname); extname = path.extname(entry); //返回路徑中文件的后綴名,即路徑中最后一個(gè)’.’之后的部分。如果一個(gè)路徑中并不包含’.’或該路徑只包含一個(gè)’.’ 且這個(gè)’.’為路徑的第一個(gè)字符,則此命令返回空字符串。 //console.log('extname返回路徑中文件的后綴名:==>'+extname); basename = path.basename(entry, extname); //返回路徑中的最后一部分 //console.log('basename返回路徑中的最后一部分:==>'+basename); pathname = path.normalize(path.join(dirname, basename)); //規(guī)范化路徑 //console.log('pathname規(guī)范化路徑:==>'+pathname); pathDir = path.normalize(pathDir); //規(guī)范化路徑 //console.log('pathDir規(guī)范化路徑:==>'+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 (開(kāi)發(fā)模式)debug = true,devServer = false,minimize = false; } else if (npm_run_type == 'dev-hrm') { // dev HRM mode (熱更新模式)debug = true,devServer = true,minimize = false; }; /* * Hrm setting * (開(kāi)啟熱更新,并自動(dòng)打開(kāi)瀏覽器) * */ 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' }}

問(wèn)題說(shuō)明 :項(xiàng)目為多入口多輸出的應(yīng)用 ,獨(dú)立合并了jquery,avalon等插件為common.js,其他單獨(dú)輸出,現(xiàn)在需要babel:es6--轉(zhuǎn)es5,但是轉(zhuǎn)完之后沒(méi)有報(bào)錯(cuò) 但是瀏覽器不能渲染。moudle的代碼被混在了common中, 整個(gè)demo chrome 不能解析

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

問(wèn)題解答

回答1:

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

回答2:

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

問(wèn)題解決 就是添加了minChunks: Infinity 參數(shù) ,和babel配置沒(méi)關(guān)系,問(wèn)的題目有一點(diǎn)問(wèn)題,我把網(wǎng)上轉(zhuǎn)的api翻譯留在這把,謝謝樓上的兄弟

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

轉(zhuǎn)自:http://www.cnblogs.com/sloong...

標(biāo)簽: JavaScript
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
午夜日韩电影| 亚洲成人激情综合网| 欧美三区在线观看| 久久美女艺术照精彩视频福利播放| 国产精品不卡一区二区三区| 亚洲成人免费电影| 一区二区毛片| 91精品国产综合久久久久久| 中文字幕视频一区| 国产真实乱对白精彩久久| 欧美人与禽猛交乱配视频| 欧美精品一区二区三| 性久久久久久久| 亚洲乱亚洲高清| 91超碰这里只有精品国产| 日韩电影免费在线| 国产精品国产亚洲精品看不卡15| 色悠久久久久综合欧美99| 精品久久久久久综合日本欧美| 亚洲免费观看高清完整| 久久99精品国产麻豆不卡| 国产一在线精品一区在线观看| 国产女主播视频一区二区| 国产自产视频一区二区三区| 欧美系列在线观看| 亚洲视频在线观看一区| 福利一区在线观看| 免费亚洲婷婷| 欧美国产精品一区二区三区| 国内成人免费视频| 4438亚洲最大| jlzzjlzz亚洲女人18| 91黄色免费网站| 亚洲日本乱码在线观看| 一区二区日韩免费看| 亚洲国产欧美在线| 黄色成人在线网站| 精品国产一二三区| 欧美阿v一级看视频| 91精品国产欧美一区二区18| 亚洲 欧美综合在线网络| 性欧美长视频| 久久精品国产免费| 国产伦精品一区二区三区视频孕妇| 久久久久99精品国产片| 欧美日韩国内| 欧美日本视频在线| 午夜免费欧美电影| 精品99视频| 亚洲电影一级片| 欧美午夜在线一二页| 国产精品66部| 欧美日韩一二三区| 大白屁股一区二区视频| 欧美日韩国产精品自在自线| 国产成人综合视频| 欧美卡1卡2卡| 麻豆精品蜜桃视频网站| 久久久777| 一区二区三区在线视频观看| 欧美精品二区| 亚洲乱码国产乱码精品精的特点| 欧美日韩国产高清视频| 日韩毛片一二三区| 色狠狠色噜噜噜综合网| 成人黄色电影在线 | 91香蕉视频mp4| 制服丝袜日韩国产| 欧美另类高清视频在线| 天堂av在线一区| 国产精品一国产精品k频道56| 亚洲国产精品av| 国产精品久久久一区二区三区| 黄色成人免费在线| 亚洲国产激情av| 一道本成人在线| 成人小视频在线观看| 夜夜精品浪潮av一区二区三区| 7777精品伊人久久久大香线蕉的| 欧美精品成人| 久久精品国产精品亚洲红杏| 亚洲国产电影在线观看| 91黄色激情网站| 92精品国产成人观看免费| 精品国产乱码久久久久久牛牛| 欧美先锋影音| 久久av资源网| 国产精品三级电影| 日韩视频一区二区三区在线播放免费观看| 日本成人中文字幕在线视频| 久久久99久久| 亚洲大胆女人| 一区二区三区四区五区视频在线观看| 欧美图区在线视频| 欧美日韩一区在线视频| 日本sm残虐另类| 欧美高清一级片在线| 欧美精品亚洲| 日一区二区三区| 国产午夜精品福利| 在线一区二区观看| 国内精品久久国产| 国产成人在线看| 亚洲chinese男男1069| 久久精品夜色噜噜亚洲aⅴ| 欧美午夜精品一区| 亚洲久久视频| av午夜一区麻豆| 日韩精品高清不卡| 中文字幕免费在线观看视频一区| 欧美探花视频资源| 国产精品亚洲不卡a| 欧美国产综合视频| 国产精品一二三四五| 午夜精品视频一区| 国产精品欧美极品| 日韩视频一区在线观看| 91毛片在线观看| 日韩高清中文字幕一区| 亚洲欧洲在线观看av| 精品少妇一区二区三区日产乱码| 色婷婷综合久久久中文字幕| 亚洲国产清纯| 日韩va亚洲va欧美va久久| 国产午夜一区二区三区| 91 com成人网| 在线观看视频一区二区 | 丝袜脚交一区二区| 成人欧美一区二区三区1314| 欧美大片一区二区| 激情文学一区| 国产激情视频一区二区三区欧美 | 99视频在线精品| 国产在线不卡一卡二卡三卡四卡| 精品国产露脸精彩对白| 葵司免费一区二区三区四区五区| 在线观看亚洲视频啊啊啊啊| 99国产精品国产精品久久| 国产露脸91国语对白| 免费成人在线观看视频| 亚洲夂夂婷婷色拍ww47| 91精品午夜视频| 在线免费一区三区| 亚洲一区黄色| 国产主播一区| 91亚洲午夜精品久久久久久| 国产黄色成人av| 国内成人精品2018免费看| 人人爽香蕉精品| 婷婷综合五月天| 亚洲午夜国产一区99re久久| 成人免费在线视频观看| 国产精品看片你懂得| 国产日产欧美一区二区三区| 2023国产精华国产精品| 国产精品三上| 在线观看亚洲视频啊啊啊啊| 欧美日韩一区二区三区在线观看免| 91免费看`日韩一区二区| 高清国产一区二区| 成人精品鲁一区一区二区| 国产精品资源在线看| 国产永久精品大片wwwapp| 精久久久久久久久久久| 精品一区二区久久久| 久久99精品久久久久| 国内成+人亚洲+欧美+综合在线| 看国产成人h片视频| 久久国产欧美日韩精品| 麻豆精品久久久| 韩国av一区二区| 国产一区二区三区久久久| 韩国毛片一区二区三区| 国产精品亚洲视频| 国产1区2区3区精品美女| 国产经典欧美精品| 国产成人精品aa毛片| 成人性生交大合| 91小视频在线观看| 欧美日韩网址| 亚洲高清激情| 国产欧美一区二区色老头| 欧美亚洲自偷自偷| 欧美四级电影在线观看| 3751色影院一区二区三区| 91精品欧美福利在线观看| 精品国产一二三| 国产欧美一区二区精品秋霞影院| 久久久国产精品麻豆| 国产色综合久久| 国产精品久久久久久久久晋中 | 国产在线精品不卡| 国产成人午夜高潮毛片| 不卡av电影在线播放| 欧美三区美女| 中文国产一区| 色诱视频网站一区| 91精品国产全国免费观看| 久久精品一区二区| 亚洲九九爱视频|