摘要:从出来接着我们看大法,打印一下感觉之前所以的对象都放在了一个合集里,给人而全的感觉里面主要含有一个对象,,输出的,等给每次打包一个值,代表唯一性天啊
从compilation出来
接着我们看
const stats = new Stats(compilation);Stats.js
log大法,打印一下 stats
let Stats = { compilation:{ _pluginCompat: SyncBailHook { _args: [Array], taps: [Array], interceptors: [], call: [Function: lazyCompileHook], promise: [Function: lazyCompileHook], callAsync: [Function: lazyCompileHook], _x: undefined }, hooks: { buildModule: [SyncHook], rebuildModule: [SyncHook], failedModule: [SyncHook], succeedModule: [SyncHook], addEntry: [SyncHook], failedEntry: [SyncHook], succeedEntry: [SyncHook], dependencyReference: [SyncWaterfallHook], finishModules: [SyncHook], finishRebuildingModule: [SyncHook], unseal: [SyncHook], seal: [SyncHook], beforeChunks: [SyncHook], afterChunks: [SyncHook], optimizeDependenciesBasic: [SyncBailHook], optimizeDependencies: [SyncBailHook], optimizeDependenciesAdvanced: [SyncBailHook], afterOptimizeDependencies: [SyncHook], optimize: [SyncHook], optimizeModulesBasic: [SyncBailHook], optimizeModules: [SyncBailHook], optimizeModulesAdvanced: [SyncBailHook], afterOptimizeModules: [SyncHook], optimizeChunksBasic: [SyncBailHook], optimizeChunks: [SyncBailHook], optimizeChunksAdvanced: [SyncBailHook], afterOptimizeChunks: [SyncHook], optimizeTree: [AsyncSeriesHook], afterOptimizeTree: [SyncHook], optimizeChunkModulesBasic: [SyncBailHook], optimizeChunkModules: [SyncBailHook], optimizeChunkModulesAdvanced: [SyncBailHook], afterOptimizeChunkModules: [SyncHook], shouldRecord: [SyncBailHook], reviveModules: [SyncHook], optimizeModuleOrder: [SyncHook], advancedOptimizeModuleOrder: [SyncHook], beforeModuleIds: [SyncHook], moduleIds: [SyncHook], optimizeModuleIds: [SyncHook], afterOptimizeModuleIds: [SyncHook], reviveChunks: [SyncHook], optimizeChunkOrder: [SyncHook], beforeChunkIds: [SyncHook], optimizeChunkIds: [SyncHook], afterOptimizeChunkIds: [SyncHook], recordModules: [SyncHook], recordChunks: [SyncHook], beforeHash: [SyncHook], contentHash: [SyncHook], afterHash: [SyncHook], recordHash: [SyncHook], record: [SyncHook], beforeModuleAssets: [SyncHook], shouldGenerateChunkAssets: [SyncBailHook], beforeChunkAssets: [SyncHook], additionalChunkAssets: [SyncHook], additionalAssets: [AsyncSeriesHook], optimizeChunkAssets: [AsyncSeriesHook], afterOptimizeChunkAssets: [SyncHook], optimizeAssets: [AsyncSeriesHook], afterOptimizeAssets: [SyncHook], needAdditionalSeal: [SyncBailHook], afterSeal: [AsyncSeriesHook], chunkHash: [SyncHook], moduleAsset: [SyncHook], chunkAsset: [SyncHook], assetPath: [SyncWaterfallHook], needAdditionalPass: [SyncBailHook], childCompiler: [SyncHook], normalModuleLoader: [SyncHook], optimizeExtractedChunksBasic: [SyncBailHook], optimizeExtractedChunks: [SyncBailHook], optimizeExtractedChunksAdvanced: [SyncBailHook], afterOptimizeExtractedChunks: [SyncHook] }, name: undefined, compiler: { _pluginCompat: [SyncBailHook], hooks: [Object], name: undefined, parentCompilation: undefined, outputPath: "/Users/orion/Desktop/react-beauty-highcharts/dist", outputFileSystem: [NodeOutputFileSystem], inputFileSystem: [CachedInputFileSystem], recordsInputPath: undefined, recordsOutputPath: undefined, records: [Object], removedFiles: Set {}, fileTimestamps: Map {}, contextTimestamps: Map {}, resolverFactory: [ResolverFactory], resolvers: [Object], options: [Object], context: "/Users/orion/Desktop/react-beauty-highcharts", requestShortener: [RequestShortener], running: true, watchMode: false, watchFileSystem: [NodeWatchFileSystem], dependencies: undefined, _lastCompilationFileDependencies: [SortableSet], _lastCompilationContextDependencies: [SortableSet] }, resolverFactory: ResolverFactory { _pluginCompat: [SyncBailHook], hooks: [Object], cache1: [WeakMap], cache2: [Map] }, inputFileSystem: CachedInputFileSystem { fileSystem: NodeJsInputFileSystem {}, _statStorage: [Storage], _readdirStorage: [Storage], _readFileStorage: [Storage], _readJsonStorage: [Storage], _readlinkStorage: [Storage], _stat: [Function: bound bound ], _statSync: [Function: bound bound ], _readdir: [Function: bound readdir], _readdirSync: [Function: bound readdirSync], _readFile: [Function: bound bound readFile], _readFileSync: [Function: bound bound readFileSync], _readJson: [Function], _readJsonSync: [Function], _readlink: [Function: bound bound readlink], _readlinkSync: [Function: bound bound readlinkSync] }, requestShortener: RequestShortener { currentDirectoryRegExp: /(^|!)/Users/orion/Desktop/react-beauty-highcharts/g, parentDirectoryRegExp: /(^|!)/Users/orion/Desktop/g, buildinsAsModule: true, buildinsRegExp: /(^|!)/Users/orion/Desktop/react-beauty-highcharts/node_modules/webpack/g, cache: [Map] }, options: { entry: "./src/index.js", output: [Object], module: [Object], devServer: [Object], externals: [Array], mode: "development", plugins: [Array], devtool: "eval-cheap-module-source-map", context: "/Users/orion/Desktop/react-beauty-highcharts", cache: true, target: "web", node: [Object], performance: false, optimization: [Object], resolve: [Object], resolveLoader: [Object] }, outputOptions: { filename: "index.js", path: "/Users/orion/Desktop/react-beauty-highcharts/dist", libraryTarget: "commonjs2", pathinfo: true, chunkFilename: "[id].index.js", webassemblyModuleFilename: "[modulehash].module.wasm", library: "", hotUpdateFunction: "webpackHotUpdate", jsonpFunction: "webpackJsonp", chunkCallbackName: "webpackChunk", globalObject: "window", devtoolNamespace: "", sourceMapFilename: "[file].map[query]", hotUpdateChunkFilename: "[id].[hash].hot-update.js", hotUpdateMainFilename: "[hash].hot-update.json", crossOriginLoading: false, jsonpScriptType: false, chunkLoadTimeout: 120000, hashFunction: "md4", hashDigest: "hex", hashDigestLength: 20, devtoolLineToLine: false, strictModuleExceptionHandling: false }, bail: undefined, profile: undefined, performance: false, mainTemplate: { _pluginCompat: [SyncBailHook], outputOptions: [Object], hooks: [Object], requireFn: "__webpack_require__" }, chunkTemplate: { _pluginCompat: [SyncBailHook], outputOptions: [Object], hooks: [Object] }, hotUpdateChunkTemplate:{ _pluginCompat: [SyncBailHook], outputOptions: [Object], hooks: [Object] }, runtimeTemplate:{ outputOptions: [Object], requestShortener: [RequestShortener] }, moduleTemplates: { javascript: [ModuleTemplate], webassembly: [ModuleTemplate] }, semaphore:{ available: 100, waiters: [], _continue: [Function: bound _continue] }, entries: [ [NormalModule] ], _preparedEntrypoints: [ [Object] ], entrypoints: Map { "main" => [Entrypoint] }, chunks: [ [Chunk] ], chunkGroups: [ [Entrypoint] ], namedChunkGroups: Map { "main" => [Entrypoint] }, namedChunks: Map { "main" => [Chunk] }, modules: [ [NormalModule] ], _modules:{ "/Users/orion/Desktop/react-beauty-highcharts/node_modules/babel-loader/lib/index.js!/Users/orion/Desktop/react-beauty-highcharts/src/index.js" => [NormalModule] }, cache: { "m/Users/orion/Desktop/react-beauty-highcharts/node_modules/babel-loader/lib/index.js!/Users/orion/Desktop/react-beauty-highcharts/src/index.js": [NormalModule], chunkmain: [Object] }, records: { modules: [Object], chunks: [Object] }, additionalChunkAssets: [], assets: { "index.js": [CachedSource] }, errors: [], warnings: [], children: [], dependencyFactories:{ [Function] => NullFactory {}, [Function: WebAssemblyImportDependency] => [NormalModuleFactory], [Function: WebAssemblyExportImportedDependency] => [NormalModuleFactory], [Function: SingleEntryDependency] => [NormalModuleFactory], [Function] => NullFactory {}, [Function] => NullFactory {}, [Function] => [NormalModuleFactory], [Function] => [NormalModuleFactory], [Function] => NullFactory {}, [Function] => NullFactory {}, [Function] => NullFactory {}, [Function] => [NormalModuleFactory], [Function] => NullFactory {}, [Function] => [NormalModuleFactory], [Function] => NullFactory {}, [Function] => [NormalModuleFactory], [Function] => NullFactory {}, [Function] => [ContextModuleFactory], [Function] => NullFactory {}, [Function] => NullFactory {}, [Function] => NullFactory {}, [Function] => [NormalModuleFactory], [Function] => [ContextModuleFactory], [Function] => [NormalModuleFactory], [Function] => [ContextModuleFactory], [Function] => NullFactory {}, [Function] => NullFactory {}, [Function: LoaderDependency] => [NormalModuleFactory], [Function] => [NormalModuleFactory], [Function] => [NormalModuleFactory], [Function] => NullFactory {}, [Function] => [ContextModuleFactory], [Function: ContextElementDependency] => [NormalModuleFactory], [Function] => [NormalModuleFactory], [Function] => [NormalModuleFactory], [Function] => [NormalModuleFactory], [Function] => [ContextModuleFactory] }, dependencyTemplates:{ "hash" => "", [Function] => ConstDependencyTemplate {}, [Function] => HarmonyExportDependencyTemplate {}, [Function] => HarmonyInitDependencyTemplate {}, [Function] => HarmonyImportSideEffectDependencyTemplate {}, [Function] => HarmonyImportSpecifierDependencyTemplate {}, [Function] => HarmonyExportDependencyTemplate {}, [Function] => HarmonyExportDependencyTemplate {}, [Function] => HarmonyExportSpecifierDependencyTemplate {}, [Function] => HarmonyExportImportedSpecifierDependencyTemplate {}, [Function] => HarmonyAcceptDependencyTemplate {}, [Function] => HarmonyAcceptImportDependencyTemplate {}, [Function] => AMDRequireDependencyTemplate {}, [Function] => ModuleDependencyTemplateAsRequireId {}, [Function] => AMDRequireArrayDependencyTemplate {}, [Function] => ContextDependencyTemplateAsRequireCall {}, [Function] => AMDDefineDependencyTemplate {}, [Function] => UnsupportedDependencyTemplate {}, [Function] => LocalModuleDependencyTemplate {}, [Function] => ModuleDependencyTemplateAsId {}, [Function] => ContextDependencyTemplateAsRequireCall {}, [Function] => ModuleDependencyTemplateAsId {}, [Function] => ContextDependencyTemplateAsId {}, [Function] => RequireResolveHeaderDependencyTemplate {}, [Function] => RequireHeaderDependencyTemplate {}, [Function] => RequireIncludeDependencyTemplate {}, [Function] => NullDependencyTemplate {}, [Function] => RequireEnsureDependencyTemplate {}, [Function] => ModuleDependencyTemplateAsRequireId {}, [Function] => ImportDependencyTemplate {}, [Function] => ImportEagerDependencyTemplate {}, [Function] => ImportDependencyTemplate {}, [Function] => ContextDependencyTemplateAsRequireCall {} }, childrenCounters: {}, usedChunkIds: null, usedModuleIds: null, fileTimestamps: Map {}, contextTimestamps: Map {}, compilationDependencies: Set {}, _buildingModules: Map {}, _rebuildingModules: Map {}, fullHash: "41d7d3a4c3eeb4a7fe6a4dcb5b927f6b", hash: "41d7d3a4c3eeb4a7fe6a", fileDependencies: { "/Users/orion/Desktop/react-beauty-highcharts/.babelrc", "/Users/orion/Desktop/react-beauty-highcharts/src/index.js", _sortFn: undefined, _lastActiveSortFn: undefined, _cache: undefined, _cacheOrderIndependent: undefined }, contextDependencies: { _sortFn: undefined, _lastActiveSortFn: null, _cache: undefined, _cacheOrderIndependent: undefined }, missingDependencies:{ _sortFn: undefined, _lastActiveSortFn: null, _cache: undefined, _cacheOrderIndependent: undefined } }, hash: "41d7d3a4c3eeb4a7fe6a", startTime: undefined, endTime: undefined }
感觉之前所以的对象都放在了一个合集里,给人而全的感觉
里面主要含有一个对象
inputFileSyste,options,输出的outputOptions,dependencyFactories等
给每次打包一个hash值,代表唯一性
天啊
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/101226.html
摘要:打开是个构造函数,定义了一些静态属性和方法我们先看在插件下地址上面写的解释就跟没写一样在文件下我们看到输出的一些对象方法每一个对应一个模块而在下引入的下面,我们先研究引入的对象的英文单词解释,除了最常用的点击手势之外,还有一个意思是水龙头进 打开compile class Compiler extends Tapable { constructor(context) { ...
摘要:编写良好的模块提供了可靠的抽象和封装边界,构成了一致的设计和明确的目的。块此特定术语在内部用于管理捆绑过程。捆绑包由块组成,其中有几种类型例如入口和子。总结一个块是进程中的一组模块,一个是一个发出的块或一组块。 我们先看一下 compilation是什么?是一个很大的对象打印key值 [ _pluginCompat, hooks, name, compiler, res...
为什么读webpack源码 因为前端框架离不开webpack,天天都在用的东西啊,怎能不研究 读源码能学到很多做项目看书学不到的东西,比如说架构,构造函数,es6很边缘的用法,甚至给函数命名也会潜移默化的影响等 想写源码,不看源码怎么行,虽然现在还不知道写什么,就算不写什么,看看别人写的总可以吧 知道世界的广阔,那么多插件,那么多软件开发师,他们在做什么,同样是写js的,怎么他们能这么伟大 好奇...
摘要:我们打开根据上次所返回的这个因为有了上次的基础,比较容易读了大体逻辑是这样的先定义一个空对象同上次的一个逻辑,还是一个目前的方式只有一个满足如果满足的会执行一系列函数这个函数直接结果是的影响是打比如如果满足的话当你的时候就会在页面上出 我们打开bin/cli.js根据上次所返回的Options processOptions(options)这个因为有了上次的基础,比较容易读了,大体逻辑...
摘要:接下来我看看一下函数我们先按照分支走为读取是里的对象,饶了这大的一个圈子,那么接下来一起来看一看对你的输入配置做了怎么样的处理吧 打开webpeck-cli下的convert-argv.js文件 // 定义options为空数组 const options = []; // webpack -d 检查 -d指令 if (argv.d) { //... } ...
阅读 2500·2023-04-26 02:57
阅读 1389·2023-04-25 21:40
阅读 2122·2021-11-24 09:39
阅读 3504·2021-08-30 09:49
阅读 714·2019-08-30 15:54
阅读 1147·2019-08-30 15:52
阅读 2030·2019-08-30 15:44
阅读 1258·2019-08-28 18:27