webpack resolve.alias ProvidePlugin externals

resolve.alias这个配置项相当于为文件目录配置一个别名

比如下面这样的目录结构


要在main.js中使用jquery,需要这样var $=require("./lib/jquery")。如果lib中的库很多,而且目录也很多,使用的时候就要写一长串的地址。

使用resolve.alias配置如下


module.exports = {
  entry: 
  {
    main:'./main.js',
  },
  output: {
    path:__dirname+'/dist',
    filename: '[name].js'
  },
  resolve:{
    //配置别名,在项目中可缩减引用路径
    alias: {
      jquery: "./lib/jquery"
    }
  },
  plugins: [
   
  ]
};

使用的时候,这样就可以var $=require("jquery");
配置项中,key值得配置方式也有很多种,更多的可以看这里

resolve.alias使我们不用频繁地写一长串的引用路径,但是使用的时候还是先要require,如果我们懒到require都不想写呢?ProvidePlugin这个插件就派上用场了。

webpack.config.js

var webpack=require("webpack");
module.exports = {
  entry: 
  {
    main:'./main.js',
  },
  output: {
    path:__dirname+'/dist',
    filename: '[name].js'
  },
  resolve:{
    //配置别名,在项目中可缩减引用路径
    alias: {
      jquery: "./lib/jquery"
    }
  },
  plugins: [
    //提供全局的变量,在模块中使用无需用require引入
    new webpack.ProvidePlugin({
      $: "jquery"
    }),
  ]
};

因为已经配置的别名,所以

new webpack.ProvidePlugin({ $: "jquery" })

就可以,jquery就是我们配置的别名,如果没有配置别名,则要这样写

new webpack.ProvidePlugin({ $: "./lib/jquery" })

使用的时候

var arr=[1,2,3,4];
$.each(arr,function(){
    console.log(this);
});

没毛病,但是如果没有配置ProvidePlugin,也没有require,这样写webpack打包的时候是不会报错的,浏览器运行的时候才知道错误。

不管是使用resolve.alias还是ProvidePlugin,打包的时候,webpack都会将使用到的库进行打包。打包的方式可以使用CommonsChunkPlugin这个插件再进行配置(我以前的文章中有写这个插件的详细用法)。如果我们不想webpack打包某个文件,而是直接在页面使用script标签手动引入,或者使用CDN资源的时候,externals这个配置项就起作用了。

webpack.config.js


module.exports = {
  entry: 
  {
    main:'./main.js',
  },
  output: {
    path:__dirname+'/dist',
    filename: '[name].js'
  },
  externals: { $: "window.jQuery" },
  plugins: [

  ]
};

使用

var $ = require("$");
var arr=[1,2,3,4];
$.each(arr,function(){
    console.log(this);
});

一定要记得require,不然和不配置externals没区别,不想写可以使用ProvidePlugin

externals: { $: "window.jQuery" },
  plugins: [
    //提供全局的变量,在模块中使用无需用require引入
    new webpack.ProvidePlugin({
      $: "$"
    })
  ]

打包后



然后页面上通过script标签手动引入CDN地址或者本地文件地址就行了,需要注意的是引入的顺序和依赖关系,将webpack打包的文件放到后面引入。

其实不使用externals也是可以的,我们看一下不使用externals,直接这样写

var arr=[1,2,3,4];
$.each(arr,function(){
    console.log(this);
});

打包后

当我们手动引入JQ后,$肯定是有的,没毛病。但始终感觉这样会给自己挖坑。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,721评论 7 110
  • 版权声明:本文为博主原创文章,未经博主允许不得转载。 webpack介绍和使用 一、webpack介绍 1、由来 ...
    it筱竹阅读 11,243评论 0 21
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,330评论 4 31
  • publicPath指定了一个在浏览器中被引用的URL地址。 对于使用 和 加载器,当文件路径不同于他们的本地磁盘...
    飞呀飞哥阅读 1,725评论 0 0
  • 有一句话叫:念念不忘,必有回响。 这句话,没错,还很有道理。它包含着人类最执着的情感,从未放弃的信念,以及在一开始...
    哇啦小姐阅读 955评论 4 2