webpack的版本已经是来到了4.0,口号是无配置就可以使用webpack,当然是使用一些基本的功能

  1.安装以下webpack的一些必须npm包

    npm install webpack

    npm install webpack-cli

    npm init -y   初始化环境,这样就给你生成了一个package.json 文件

  执行完之后大致的目录结构是

  

  2.按照惯例我们往项目上添加一些初始文件及文件夹

    添加 index.html 在根目录上

    添加src/index.js

    index.js 内部的内容就是console.log(1)

  1. console.log(1)

  

  3.上面初始结构就可以用了,webpack 4 又一份默认配置,入口文件就是src/index.js 而出口文件就是dist/main.js

    接着我们执行 npx webpack ,这样我们就会生成一个dist文件夹,里面又一个main.js 文件

  

  4.下面我们简单的验证一下功能,修改一下index.js的内容

    在src的目录下添加print.js

  1. const printholle = function (key) {
  2. console.log(key)
  3. }
  4.  
  5. export default printholle

    修改后的index.js的内容

  1. import printholle from './print'
  2.  
  3. printholle('11111')
  4. console.log(1)

    直接在index.html 中引入index.js,然后再浏览器中运行

  明显可以看到,import是不被识别的

    我们尝试npm进行编译打包,从新再index.html中引入,查看运行结果,结果可行,这么我们就可以开始模块化开发了

  2.上面只是简单的做了一些尝试,使用的是一些默认的配置,下面我们尝试自己去配置一下配置文件

    首先我们再根目录上创建配置文件webpack.config.js ,因为打包其实本身是一个node程序,所以再配置文件上我们都是一些node的写法

    最基础的当然是一个入口文件和一个出口文件

  1. const path = require(‘path’)
  2.  
  3. module.exports = {
  4. entry: './src/index.js',
  5. output: {
  6. filename: 'builde.js',
  7. path: path.resolve(__dirname, 'dist')
  8. }
  9. }

  entry  是入口文件  output 是出口文件  output.filename 是打包之后的文件名,执行npx webpack之后,我们再在index.html引入,我们也可以的到刚才引入main.js

  的结构

  

  webpakc.config.js中肯定不是仅仅只有出口和入口配置

   我们接下来看一下module ,这里是我们常常引入loader的地方,常的loader 例如 css-loader style-loader less-loader file-loader vue-loader 等等

  如果我们想在js中引入less样式表的话

  我们需要安装一写loader  如css-loader style-loader less-loader 还需要安装less

  webpack.config.js中的mudule配置,, 一定要注意的一个点是多个loader的引用顺序,less的顺序是style-loader,css-loader,less-loader

  整个loader的使用其实是逆序的 先使用less-loader 然后使用css-loader 最后使用css-loader.

  1. const path = require('path')
  2.  
  3. module.exports = {
  4. entry: './src/index.js',
  5. output: {
  6. filename: 'bundle.js',
  7. path: path.resolve(__dirname,'dist')
  8. },
  9. module: {
  10. rules: [
  11. {
  12. test: /\.less$/,
  13. use: [
  14. 'style-loader',
  15. 'css-loader',
  16. 'less-loader'
  17. ]
  18. },
  19. {
  20. test: /\.(png|svg|jpg|gif|)$/,
  21. use: [
  22. 'file-loader'
  23. ]
  24. }
  25. ]
  26. }
  27. }

    下面是整个代码结构

  

  在js中import less     import '../assets/css/index.less';

  less中的代码

  1. h1{
  2. color: red;
  3. font-size: 18px;
  4. span {
  5. color: aqua;
  6. }
  7. }

  

  引入less之后我们在浏览器中看到的结果

  如果我们想在js中是用图片的话,那么我们就需要使用file-loader,webpack的配置是下面这样的

  如果想使用字体的话,也是同样使用的file-loader

  1. {
  2. test: /\.(png|svg|jpg|gif|)$/,
  3. use: [
  4. 'file-loader'
  5. ]
  6. }
  1. {
  2. test: /\.(woff|woff2|eot|ttf|otf)$/,
  3. use: [
  4. 'file-loader'
  5. ]
  6. }

  这样的话,我们就基本熟悉的一些简单的webpack的配置使用。后续会再慢慢去深入。

  平常开发,初始化构建项目时,基本上都是使用成熟的脚手架,好多配置都是直接搬过来用,导致对于webpack本身了解的不够。

  随着开发进行项目变得越来越是庞大,每一次构建、打包也是越来越来慢,打包之后的文件也越来越大,这样使得基本的一些需求配置已经满足不了

  我们的项目开发。是时候对webpack进行一个深入学习了。

  

webpack搭建前端开发环境的更多相关文章

  1. 从零开始使用 Webpack 搭建 Vue3 开发环境

    从零开始使用 Webpack 搭建 Vue3 开发环境 创建项目 首先需要创建一个空目录,在该目录打开命令行,执行 npm init 命令创建一个项目,这个过程会提示输入一些内容,完成后会自动生成一个 ...

  2. webpack 4.x之搭建前端开发环境

    webpack是一个现代JavaScript应用程序的静态模块打包器,借用官网的一张图,它能够将一些预处理语言,js的最新语法转换成浏览器识别的内容.现在一般的前端框架都有比较成熟的脚手架,大多数对w ...

  3. 使用vue-cli+webpack搭建vue开发环境

    在这里我真的很开心,好久没有用过博客,今天突然看到了我的博客有不少人看过,虽然没有留下脚印,但是还是激起了我重新拿起博客的信心,感谢大家. 在这里我们需要首先下载node,因为我们要用到npm包下载, ...

  4. 手把手教你如何用eclipse搭建前端开发环境

    3.创建静态web工程 打开eclipse,选择file,new project 或者 new other...,选择web项中的static web project ,next. 输入你的项目名,如 ...

  5. 1 使用webpack搭建vue开发环境

    1 先去node.js官网下载nodejs并且安装 安装成功之后在命令行输入node -v 回车,npm -v回车如果显示对应的版本号,说明node安装成功,自带的npm也安装成功 2 在d盘下创建一 ...

  6. 使用webpack搭建react开发环境

    安装和使用webpack 1.初始化项目 mkdir react-redux && cd react-redux npm init -y 2.安装webpack npm i webpa ...

  7. Windows环境下sublime text 3搭建前端开发环境

    一.安装SubLime Text 3 SubLime Text 3官网下载:https://www.sublimetext.com/ 二.安装Package Control 进入sublime后,按快 ...

  8. 使用webpack搭建vue开发环境

    最近几天项目上使用了vue.js作为一个主要的开发框架,并且为了发布的方便搭配了webpack一起使用.CSS框架使用的是vue-strap(vue 对bootstrap控件做了封装)这篇文章主要总结 ...

  9. 从零开始使用 Webpack 搭建 Vue 开发环境

    创建项目 先创建一个空目录,在该目录打开命令行,执行 npm init 命令创建一个项目(无法执行 npm 命令?需要先安装 Node),这个过程会提示输入一些内容,随意输入就行,完成后会自动生成一个 ...

随机推荐

  1. Linux下kafka集群的搭建

    上一篇日志已经搭建好了zookeeper集群,详细请查看:http://www.cnblogs.com/lianliang/p/6533670.html,接下来继续搭建kafka的集群 1.首先下载k ...

  2. 品 SpringBootApplication 注解源码

    @SpringBootApplication 由以下三个注解构成: @SpringBootConfiguration@EnableAutoConfiguration@ComponentScan 一:@ ...

  3. JS箭头函数的this

    箭头函数的this看定义他的时候,他的外层有没有函数 有:外层函数的this就是箭头函数的this 无:箭头函数的this就是window obj = {age:18, getAge: ()=> ...

  4. 【转载】Linux的五个查找命令

    原文:http://www.ruanyifeng.com/blog/2009/10/5_ways_to_search_for_files_using_the_terminal.html 最近,我在学习 ...

  5. JS检测浏览器版本信息(包含IE11),并动态添加样式

    <head runat="server"> <meta http-equiv="Content-Type" content="tex ...

  6. 批处理bat相关

    时间 %date:~0,4%%date:~5,2%%date:~8,2%_%time:~0,2%%time:~3,2%%time:~6,2% 判断 if %date:~2,1%==/ (echo en ...

  7. 有关二次离线和 Yuno loves sqrt technology II

    二次离线 前置技能 莫队 修改查询 \(O(\sqrt n )-O(1)\) 平衡 概念 考虑朴素莫队离线询问,过程中维护信息从 \([l,r]\) 扩展为 \([l\pm 1,r\pm 1]\) , ...

  8. [Flask]常用过滤器-控制字符串

    truncate: 字符串截断 <p>{{ 'hello every one' | truncate(9)}}</p> length:获取列表长度 <p>{{ [, ...

  9. Selenium 2自动化测试实战9(简单元素操作)

    一.简单元素操作 1. webdriver中常用的几个方法: clear():清除文本 send_keys(*value):模拟按键输入 click():单击元素 clear()方法用于清除文本输入框 ...

  10. mysql 8.0.12 安装配置方法图文教程

    一.安装 1.从网上下载MySQL8.0.12版本,下载地址 2. 下载完成后解压 我解压的路径是:D:\Java\mysql-8.0.12-winx64 3. 配置文件 首先在解压的路径下查看是否含 ...