webpack

一、

1.webpack通过loader可以支持各种语言预处理器编写模块。webpack的各种loader描述了webpack如何处理非javascript模块,并且在bundle(包)中引入这些依赖。被用于转换某些类型的模块。
2.即webpack可以使用loader来预处理文件。允许打包除javascipt之外的任何静态资源。可以在import或“加载模块”时预处理文件。
3.loader可以将所有类型的文件转换为webpack能够处理的有效模块,然后利用webpack的打包能力,对他们进行处理。
webpack官方loader

预处理器是在真正的编译开始之前由编译器调用的独立程序。预处理器可以删除注释,包含其它文件以及执行宏替代等。

在应用程序中有三种使用loader的方式:

  • 配置(推荐):在webpack.config.js文件中指定loader

嘿,webpack编译器,在你碰到 【在require()/import语句中被解析为'.css'的路径】时,在你对它进行打包之前,先用style-loader和css-loader转换一下。

//1.命令行运行:先安装所需对应的loader
npm install -D css-loader ts-loader
//2.配置方式使用loader(常用)
//webpack的js配置文件:
moudle.exports = {
  moudle:{
    rules:[
      { test:/\.css$/,  //必须属性,标识出应该被对应的loader进行转换的某个或某些文件
        use:[  //必须属性,表示进行转换时,应该使用哪个loader
          { loader:'style-loader '},
          {
            loader:'css-loader',
            options:{ //这是loader的额外配置项
              modules:true
            }
          }
      ]},
      {test:/\.ts$/, use:'ts-loader'}
    ]
  }
}
  • 内联:在每个import语句中显示指定loader
//2.内联方式使用loader
import css from ' !style-loader!cdd-loader!./css/index.css'
  • CLI:在shell(命令行)命令中指定它们。
//3.CLI方式使用loader:会对.jade文件使用jade-loader,会对.css文件使用style-loader和css-loader
webpack --module-bind jade-loader --module-bind 'css=style-loader!css-loader'

loader常用于:压缩,打包,语言翻译等

二、

webpack插件列表
1.loader被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务,包括打包优化、压缩和重新定义环境中的变量等。插件是webpack生态系统的重要组成部分,为社区用户提供了一种强大方式来直接触及webpack的编译过程。
2.使用:

  • require()插件
  • 将插件添加到plugins数组里。多数插件可以通过选项option自定义
  • 使用new操作符来创建它的一个实例
const HtmlWebpackPlugin = require('html-webpack-plugin')
const config = {
  plugins : [
    new HtmlWebpackPlugin(template :'./src/index.html')
  ]
}

三、

1.output.path 是所有打包后的文件输出的目标路径,必须是绝对路径。比如:output输出的js,url-loader解析的图片,HtmlWebpackPlugin生成的html文件,都会存放在以output.path为基础的目录下。
2.out.publicPath并不会对生成文件的路径造成影响,主要是对你的页面引入的资源的路径做对应的补全。常见的就是css文件里面引入的图片。html里引入的资源路径会手动改变,没有影响。

module.exports = {
  output : {
    filename : 'js/[name].js',  //[name]表示出口文件的名字和入口文件名字一样
    path : path.resolve(__dirname , 'dist')  
    publicPath : './dist/'
  }
}

__dirname 表示当前文件所在目录的绝对路径
__filename 表示当前文件的绝对路径
path.resolve() 将从右到左对给定路径进行处理,生成绝对路径

参考理解示例

四、

webpack-dev-server的相关配置

1.

webpack-dev-serve是webpack官方提供粉人一个小型Express服务器,可以为打包生成的资源文件提供web服务。主要有两个功能:

  • 为静态文件提供服务
  • 自动刷新和热替换(HMR)

2.常用配置项

module.exports = {
  devServe : {
    contentBase : '/dist', 
    compress : true, //是否启用服务器压缩
    port: 7777,
    host :'127.7.7.1',
    proxy:{
      '/api/v1/user' : { //匹配满足/api/v1/user这种格式的请求地址
        target : 'http://gs.uestc1.com',
        changeOrigin : true
      },
      '/api' : {
        target : 'http://gs.uestc2.com',
        changeOrigin : true
      },
      '/test' : {
        target : 'http://gs.uestc3.com',
        changeOrigin : true
      },
    }
  }
}

示例:dev-serve如上配置

1.请求1的地址:/api/v1/user/staff

  • 配置的有host,所有请求会自动补充前缀。完整请求地址为:http://127.7.7.1:7777/api/v1/user/staff
  • 使用了http-proxy进行代理重定向地址,代理从上到下依次匹配请求地址的格式,若满足则重定向到配置的新地址。
  • 这里,请求1的地址能匹配到第一个/api/v1/user,所以该请求地址将会从http://127.7.7.1:7777/api/v1/user/staff重定向到 http://gs.uestc1.com/api/v1/user/staff这个地址去请求数据。
  • 这个重定向是后台进行,所以浏览器的上显示的地址还是host地址:http://127.7.7.1:7777/api/v1/user/staff

注意:如果大范围匹配的请求地址包含小范围匹配的地址,那么小范围的匹配必须写在大范围匹配的前面,不然小范围的匹配不会生效。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • 写在前面的话 阅读本文之前,先看下面这个webpack的配置文件,如果每一项你都懂,那本文能带给你的收获也许就比较...
    不忘初心_9a16阅读 3,233评论 0 17
  • 版权声明:本文为博主原创文章,未经博主允许不得转载。 webpack介绍和使用 一、webpack介绍 1、由来 ...
    it筱竹阅读 11,106评论 0 21
  • 一、概念 本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bun...
    Timmy小石匠阅读 1,952评论 0 29
  • 目录第1章 webpack简介 11.1 webpack是什么? 11.2 官网地址 21.3 为什么使用 web...
    lemonzoey阅读 1,733评论 0 1
  • 灯破盏 酒酣漓 萤衣如火 似明似现 抽刀断魂 解下缠恋 若有若无 春风来之前...
    竹音尘阅读 166评论 0 3