webpack

是一个模块打包器,能够把所有的文件都当做是一个模块

它把所有的文件资源(js,json,css,sass,图片)都看作为模块

将这些文件资源解析处理以后,生成对应的打包文件

使用webpack构建一些应用也是非常方便,比如基于

node webpack vue-cli构建vue程序(脚手架)

webpack是一个基于node.js运行环境,用于打包本地文件

之间相互依赖并最终输出成单个文件的工具,就像npm工具可以下载安装包一样

webpack能够帮助我们解决

1.打包js文件

 文件结构
  dist目录
  src目录
  app.js
  1.js
  index.html
  • 在项目的根目录下面初始化

npm init -y

  • 装包 webpack

npm install webpack@3 -g

  • 打包

webpack 源文件路径 打包到新文件路径

webpack ./src/app.js ./dist/bundle.js

  • 在index.html中 引入打包后的文件路径

配置 行命令繁琐

在新项目根目录下新建一个文件:webpack.config.js

2.打包json文件

直接暴露,然后引入即可,js插件解决

3.打包css文件

  • 安装:npm i style-loader css-loader -D

  • 创建style.css 并书写相关样式

  • app.js中引入:require('./style.css')或者 import css from './style.css'//引入时加后缀名

  • 配置 在webpack .config.js 加入

    •  module:{
        rules:[{
        test:/\.css$/,//解析css
        use:['style-loader','css-loader']//从右向左解析
        }]
        }
  • 在cmd 运行webpack进行打包

4.打包css中的图片

  • 安装:npm i url-loader file-loader -D

  • 配置webpack.config.js (放在reules配置css下面)

      use:[{
      loader:'url-loader',
      option:{
      limit:8192,
     
      }
      }]
  • 运行cmd webpack打包

5.打包处理页面里面的img标签

  • 安装 npm install html-withimg-loader --save

  • 运行 webpack.config.js中配置modules.rules(放在图片下面)

     {
      test:/\(htm|html$/i,
      loader:'html-withimg-loader'
     }
  • 使用插件html-webpack-plugin

    需要下载webpack到本地

    npm install --save-dev webpack@3

  • 下载包

    npm i html-webpack-plugin -S

  • 插件放在module 后面

     配置
      filename
      就是html文件的文件名,默认是index.html
      template
      指定你生成的文件所依赖哪一个html文件模板,模板类型可以是html、jade、ejs等
      。但是要注意的是,如果想使用自定义的模板文件的时候,你需要安装对应的loader哦。
      //引入
      var htmlWebpackPlugin = require('html-webpack-plugin')
     
      //插件 放在module 后面
      plugins:[
      new htmlWebpackPlugin({
      //生成的html文件 不用指定输出目录 因为出门文件已经设置
      filename:"a.html",
      //已经有的html 模板
      template:"./index.html" //打包页面
      })
      ]

    压缩js

     为什么要压缩?
     压缩文件可以减少文件大小,可以去除不必要的空格和换行,对于图片文件
     可以把质量调低,文件大小 小了,网络字节量也就小了,用户下载速度就
     会变快

    如果是新建的文件目录:那么需要初始化:

    npm init -y

  • 安装webpack@3.1.0

    • npm i --save-dev webpack@3.1.0

  •  webpack.config.js文件中新添加一个插件
      var webpack = require("webpack");
      //plugins: [new webpack.optimize.UglifyJsPlugin() // 压缩js文件]
      plugins:[
      new htmlWebpackPlugin({
      //生成的html文件 不用指定输出目录 因为出门文件已经设置
      filename:"a.html",
      //已经有的html
      template:"./index.html"
      }),
      new webpack.optimize.UglifyJsPlugin(), //压缩js文件
      //单独打包 生成的路径的
      // new ExtractTextPlugin("style.css"),
      //压缩
      // new OptimizeCssplugin()
      ]
  • 运行cmd 进行压缩

压缩css文件

  • 安装包:npm i --save-dev extract-text--webpack-plugin@3.0.2

  • 安装压缩css文件的插件

    • npm install --save-dev optimize-css-assets-webpack-plugin@3.2.0

  • 在webpack.config.js中配置

压缩图片文件

  • 新建文件目录

    dist

    src

    加载图片

    1.jpg

    app.js:引入图片

    webpack.config.js配置文件

  • 初始化:

    • npm init -y

  • 安装包

    • npm i --save-dev url-loader@1.1.2 file-loader@2.0.0 image-webpack-loader@4.6.0

  • 安装webpack到本地

    • npm i --save-dev webpack@3

  • 在index.js导入这章图片

    • import "./1.png"

  • 运行cmd webpack进行打包压缩

雪碧图

  • 新建文件目录

dist

src

icons 图标

app.js

index.html

  • 初始化包

    • npm init -y

  • 安装

    • npm install webpack-spritesmith@1.0.0

  • 安装webpack

    • npm install webpack@3 --save-dev

  • 安装 html-webpack-plugin插件

    • npm i --save-dev html-webpack-plugin@3.2.0

  • 安装导入

    • const WebpackPlugin = require('html-webpack-plugin')

    • const Spritesmith

  •  target :{
      //生成雪碧图(大图)文件存放路径
      image:path.resolve(__dirname,'dist/sprite/sprite.png'),
      css:path.resolve(__diname,'dist/sprite/sprite.css')
     
     },
      //样式文件中 雪碧图的写法
      apiOptions:{
      al
      }
  • 在根目录index.html中

     <link rel="stylesheet" href="./sprite.css">
      </head>
     <body>
      <div id="one"></div>
      <div id="two"></div>
      <div id="three"></div>
     
     </body>
     ​
  • 在app.js中

     document.getElementById("one").classList.add("icon-4");
     document.getElementById("two").classList.add("icon-2");
     document.getElementById("three").classList.add("icon-right");
  • 在webpack.config.js中配置

     在plugins下添加
      new WebpackHtmlPlugin({
      template:"./src/index.html"
      })
     ​
  • 运行cmd webpack 将在 dist目录下生成 一个文件夹和一个html,里面有打包的精灵图,打开html即可在网页中看到精灵图

关于webpack的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. webpack之傻瓜式教程

    接触webpack也有挺长一段时间了,公司的项目也是一直用着webpack在打包处理,但前几天在教新人的情况下,遇到了一个问题,那就是:尽管网上的webpack教程满天飞,但是却很难找到一个能让新人快 ...

  3. 细说前端自动化打包工具--webpack

    背景 记得2004年的时候,互联网开发就是做网页,那时也没有前端和后端的区分,有时一个网站就是一些纯静态的html,通过链接组织在一起.用过Dreamweaver的都知道,做网页就像用word编辑文档 ...

  4. Webstorm+Webpack+echarts构建个性化定制的数据可视化图表&&两个echarts详细教程(柱状图,南丁格尔图)

    Webstorm+Webpack+echarts   ECharts 特性介绍 ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(I ...

  5. 使用webstorm+webpack构建简单入门级“HelloWorld”的应用&&引用jquery来实现alert

    使用webstorm+webpack构建简单入门级"HelloWorld"的应用&&构建使用jquery来实现 1.首先你自己把webstorm安装完成. 请参考这 ...

  6. webpack入门教程之Hello webpack(一)

    webpack入门教程系列为官网Tutorials的个人译文,旨在给予想要学习webpack的小伙伴一个另外的途径.如有不当之处,请大家指出. 看完入门教程系列后,你将会学习到如下内容: 1.如何安装 ...

  7. webpack的使用

    1.webpack是什么? 打包前端项目的工具(为项目提高逼格的东西). 2.webpack的基本命令 webpack#最基本的启动webpack命令 webpack-w #提供watch方法,实时进 ...

  8. Webpack 配置摘要

    open-browser-webpack-plugin 自动打开浏览器 html-webpack-plugin 通过 JS 生成 HTML webpack.optimize.UglifyJsPlugi ...

  9. Vue + Webpack + Vue-loader 系列教程(2)相关配置篇

    原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ 使用预处理器 在 Webpack 中,所有的预处理器需要和一个相应的加载器一同使用.vue- ...

  10. Vue + Webpack + Vue-loader 系列教程(1)功能介绍篇

    原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ Vue-loader 是什么? vue-loader 是一个加载器,能把如下格式的 Vue ...

随机推荐

  1. 2019-在iOS里添加admob横幅广告示例

    下载sdk , 解压 导入项目文件夹:   在info.plist里加入应用id(不是广告单元id): GADApplicationIdentifier 设置Build Settings选项 设置ap ...

  2. HOWTO: Avizo/Amira/Pergeos中如何利用Volume Edit

    操作非常简单,就是利用Volume Edit取圆柱的同时可以取一个Mask(或称之为ROI,感兴趣区域,蒙板等) 如上图,利用Volume Edit取一个圆柱,然后点击Create Mask创建一个M ...

  3. vuex详解vue简单使用

    vue概念:vuex 是 Vue 配套的 公共数据管理工具,它可以把一些共享的数据,保存到 vuex 中,方便 整个程序中的任何组件直接获取或修改我们的公共数据: 配置vuex的步骤: 1.运行cnp ...

  4. 【凭据不工作】Win远程桌面提示您的凭据不工作

    1.浏览器直接进入云服务器 2.打开运行 --输入gpedit.msc--计算机配置--管理模板--windows组件--远程桌面服务--远程桌面会话主机--安全--远程(RDP)链接要求使用制定的安 ...

  5. 猫眼电影和电影天堂数据csv和mysql存储

    字符串常用方法 # 去掉左右空格 'hello world'.strip() # 'hello world' # 按指定字符切割 'hello world'.split(' ') # ['hello' ...

  6. JSONP跨域的script标签请求为什么不受同源策略的限制?

    在复习跨域的时候,复习到了JSONP跨域,大家都知道JSONP跨域是通过动态创建script标签,然后通过其src属性进行跨域请求的,前端需要一个数据处理的回调函数,而服务端需要配合执行回调函数,放入 ...

  7. HDU-4725 The Shortest Path in Nya Graph (拆点+dji)

    HDU 4725 The Shortest Path in Nya Graph : http://acm.hdu.edu.cn/showproblem.php?pid=4725 题意: 在一个图中跑最 ...

  8. CodeForces 1083 E The Fair Nut and Rectangles 斜率优化DP

    The Fair Nut and Rectangles 题意:有n个矩形,然后你可以选择k个矩形,选择一个矩形需要支付代价 ai, 问 总面积- 总支付代价 最大能是多少, 保证没有矩形套矩形. 题解 ...

  9. 牛客暑假多校 F RIKKA with Line Graph

    题意: 现在有一副完全图, 将他转化成线图. 线图就是 把原来的图上的边都变成点, 然后如果原来的任意2条边存在公共点, 他们就会有一条边, 边权为原来的2条边的和. 最后求出线图中的任意2点的最短路 ...

  10. cve_2019_0708_bluekeep复现采坑

    0X01 简介 Microsoft Windows是美国微软公司发布的视窗操作系统.远程桌面连接是微软从Windows 2000 Server开始提供的功能组件. 2019年5月14日,微软发布了月度 ...