webpack的介绍及搭建步骤

webpack:  打包工具  前端必备

对webpack的理解:

Webpack可以看作是一个模块的打包机,它做的事情就是分析你的项目结构,找到了模块以及其它的一些浏览器不能使用的拓展语言。并将其转换和打包为合适的格式提供浏览器使用

为什么要用webpack?

Webpack 可以将多种静态资源 js、css、less 转换成一个静态文件,减少了页面的请求

webpack的作用:

                  1.打包(可以处理js的依赖关系)

                  2.转换(less,sass,loader工具处理)

                  3.优化(把优化功能做了)

webpack的一些核心东西:

                  1.入口entry

                  2.出口output

                  3.转换器loader

                  4.模式mode

                  5.服务器devServer

webpack如何初始化配置:

(1) Entry 应用程序的起点入口,可以是一个文件,如果传递一个数组,那么那么数组的每一都会执行,也可以是一个对象。

(2) Output 位于对象最顶级键(key),包括了一组选项,指示webpack 如何输出,

以及哪里输出,和他你所打包或使用webpack 载入的任何内容。

(3)Plugins引入插件

(4)loader就是webpack 用来预处理模块的,在一个模块被引入之前,会预先

用loader处理模块的内容。

webpack如何打包?

webpack entry<entry> output (命令行)

webpack -config webpack.conf.js (指定webpack的配置文件)

搭建webpack步骤:

                在C盘终端执行前三个指令

                1.(c)npm install webpack -g    全局安装webpack

                2.(c)npm install webpack-cli -g    全局安装webpack

                3.(c)npm init -y   创建webpack

                4.创建一个src源文件,src里创建两个文件index.html , index.js

                5.创建一个dist文件夹。它是打包生成的的文件,里面创建一个index.html

                6.终端: webpack src/index.js --output dist/bundle.js

                7 (或者). 配置webpack.config.js 文件

                            const path = require("path")

                            module.exports={

                                    //入口

                                  entry:"./src/index.js",

                                  //出口

                                  output:{

                                        path:path.resolve(__dirname,"dist")  // 设置默认的出口位置

                                        filename:"bundle.js"        // 设置默认的出口的文件名

                                }

                        }

                  终端 :webpack

                  在src文件夹下的index.js 引入  import ... from  "路径"

                终端 : webpack(再次打包,并删除起初dist文件夹的bundle.js)

            8.webpack-dev-server  安装,他的作用就是自动编译  热加载(局部加载)

                cnpm i webpack-dev-server -D

              如果出现图片上的警告,就输入以下指令:

                      cnpm i webpack -D

                      cnpm i webpack-cli -D( 解决警告问题)

            package中"scripts"内写入:"dev": "webpack-dev-server --open --port 8080 --contentBase src --hot" 配置在scripts对象李

                --open  自动打开浏览器 

              --port  端口号

              --contentBase  默认加载路径

              --hot  热加载

      此文件终端输入指令:  npm run dev

        然后下载插件指令:  cnpm i html-webpack-plugin -D

      可以在内存(webpack.config)中  取到 打包之后的 js文件

      const htmlWebpackPlugin = require("html-webpack-plugin");

      plugins:[

              new htmlWebpackPlugin({

                          filename:"index.html",

                        template:path.join(__dirname,"./src/index.html")

          })

      ]

    dist文件夹的index.html  文件里面引入的js 便可 去掉了

代码如下:


src文件夹的index.html的代码
src文件夹的index.js的代码


package.json的代码
webpack.config.js的代码

 

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

推荐阅读更多精彩内容

  • 前言 本文主要从webpack4.x入手,会对平时常用的Webpack配置一一讲解,各个功能点都有对应的详细例子,...
    BetterChen阅读 1,943评论 0 3
  • 前言: 拿到一个项目 , 生成默认package.json,可以执行npm init -ypackage.json...
    筱疯子阅读 1,969评论 0 0
  • 在现在的前端开发中,前后端分离、模块化开发、版本控制、文件合并与压缩、mock数据等等一些原本后端的思想开始...
    Charlot阅读 5,428评论 1 32
  • 1、webpack入门 Webpack 是一个前端资源的打包工具,它可以将js、image、css等资源当成一个模...
    余生安好178阅读 1,065评论 0 2
  • 更新:Webpack4已经发布,本篇是基于Webpack3的,请注意。更正:1.package.json中使用了应...
    HermitCarb阅读 1,228评论 2 4