zoukankan      html  css  js  c++  java
  • Vue2.0---webpack打包知识点-2

      先贴一篇对vue-cli#2.0进行webpack配置的详细分析:

      https://zhuanlan.zhihu.com/p/24322005

      一、看一下webpack的打包流程

      1、package.json中的“script”的"build": "node build/build.js",

        在build.js中      var webpackConfig = require('./webpack.prod.conf')

      2、所以我们进入到webpack.prod.conf.js中,然后又require('./webpack.base.conf')

      3、进入到webpack.base.conf.js中----重点在module.exports中:因为我们现在考虑的是单入口,所以entry一般是main.js,

        对于出口文件中的libraryTarget属性:共有四个属性值------umd,amd,commonjs,commonjs2。如果我们想开发一些工具库,这些库既可以用commonjs和

    amd方式使用也可以用script方式引入。通常我们使用umd方式打包完成之后,浏览器可以识别。项目正常运行;但是使用amd方式,会报错---提示在打包

    之后的app.js中define is not defined;使用commonjs方式,会报错---提示在打包之后的app.js中exports is not defined;使用commonjs2方式,会报错---提示在打包之后的app.js中module is not defined

      注:amd和cmd的依赖是通过define的参数来确定的,比如define('B', ['A'], () => {})就是说当前模块的名字是B,并且依赖A模块。但是实际上amd和cmd中,第一个参数不设置,因为设置了会有问题;commonjs的用法规范既是依赖一个模块就require进来,暴露出这个模块供其他模块使用就exports。

      4、我们最常使用的模块化方案是commonjs2和umd,前者是为node环境,后者是为浏览器环境。如果只是项目的话,libraryTarget属性可以不加的,如果是产品的话,需要另外讨论。

      5、对externals属性理解尚浅-----

          webpack中如果想不打包引用第三方类库、框架、自定义插件等,可以设置此属性;

          externals使用场景是外部依赖不需要打包到输出文件。

          externals: {
              jquery: 'jQuery',
          }

        最后,对libraryTarget理解也是一种朦胧的状态。

         以上。

  • 相关阅读:
    一对多关系的应用和XXX_set的用法
    《监控》读后感
    电子工业出版社博文视点Open Party 新年聚会 圆满成功召开
    《OPhone应用开发权威指南》全面上市
    《变革中的思索》连载四:PC的未来之路
    博文视点Open Party 新年大戏盛情邀约
    博文视点Open Party 新年大戏盛情邀约
    职场谍战小说《监控》在广州日报连载
    九星小说《监控》
    2010年厦门商报报导《监控》小说
  • 原文地址:https://www.cnblogs.com/Mrfan217/p/6956177.html
Copyright © 2011-2022 走看看