【JavaScript】 Webpack安装及文件打包

背景

最近开启一个新项目,需要对前端的各类资源文件进行打包,经过多方调研后,决定使用webpack工具。但是网上的教程多是将webpack直接作为服务器使用,而我只是想将其作为单纯的资源打包工具而已。经过多方调研,终于发现如何实现webpack的文件打包功能。

准备

在使用webpack之前,必须先要安装nodejs和npm。

安装完npm后,由于npm国内访问非常慢,可以设置为从淘宝的镜像下载各种资源包。

npm config set registry http://registry.cnpmjs.org

新建工程目录

安装Webpack前,需要把命令行指向目录,具体怎么跳转就不多少了,下行命令中的ReactSrc就是工程目录。

cd  目录/ReactSrc

然后进行初始化,执行下列命令后会在工程目录下生成一个package.json文件。

npm init

引入webpack工具包

这时候就可以安装Webpack包了,下面命令是将webpack安装到nodejs的全局包下。

//全局安装
npm install -g webpack

执行下面的命令,将webpack作为本次工程的依赖包。

npm install --save-dev webpack

生成资源文件

在ReactSrc文件夹下生成两个文件夹,app和public。

app用来放js及数据等资源文件。

public用来放供用户访问的html文件。

这样,在ReactSrc下的目录结构如下:

在app下生成Greeter.js和main.js。

Greeter.js ,用来创建一个div,并在div中显示欢迎的内容。

module.exports = function() {
  var greet = document.createElement(‘div‘);
  greet.textContent = "Hi there and greetings!";
  return greet;
};

main.js,工程的主入口文件。

var greeter = require(‘./Greeter.js‘);
document.getElementById(‘root‘).appendChild(greeter());

在public下生成一个index.html

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title>Webpack Sample Project</title>
  </head>
  <body>
    <div id=‘root‘>
    </div>
    <script src="bundle.js"></script>
  </body>
</html>

这时候会发现,在index.html中,引用了一个bundle.js,但是我们在app中并没有看到这个js啊。

不用担心,如何生成bundle.js就是我们这节的重头戏【用webpack打包并生成js文件】!

webpack打包配置

其实很简单,在导入webpack依赖包时,有一个webpack.config.js,打开后写入一下内容:

var config = {
   entry: ‘./app/main.js‘, // 入口文件

   output: {
      path:‘./public‘,
      filename: ‘bundle.js‘, // 生成的结果文件
   },

   module: {
      loaders: [ {
         test: /\.jsx?$/,
         exclude: /node_modules/,
         loader: ‘babel‘,

         query: {
            presets: [‘es2015‘, ‘react‘]
         }
      }]
   }

}

module.exports = config;

在这个文件中,我们可以看到webpack的打包配置,意思就是读取app目录下的main.js文件,在public文件夹下生成bundle.js文件。

配置完后,我们再打开初始化工程(npm init)时,生成的package.json文件。

在这个文件中,我们会看到其中有执行webpack打包命令。

{
  "name": "reactapp",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "start": "webpack" // 执行webpack 打包命令
  },
  "author": "linh",
  "license": "ISC",
  "dependencies": {
    "react": "^15.3.1",
    "react-dom": "^15.3.1"
  },
  "devDependencies": {
    "webpack": "^1.13.2",
    "webpack-dev-server": "^1.16.1"
  }
}

开始打包

现在万事俱备,只欠东风了。打开命令行,执行如下命令,npm就会自动调用webpack,对工程中的js文件进行打包生成。

npm start

这时,打开public目录,会发现目录下多了一个bundle.js。直接在浏览器中打开该目录下的index.html,显示如下。

时间: 2024-10-18 02:18:41

【JavaScript】 Webpack安装及文件打包的相关文章

webpack的多文件打包问题

1.第三方库如vue,vue-router可以利用webpack中的entry指定vendor:['vue','vue-router']来打包在一个文件中 2.将这些文件单独提取出来,在页面中使用<script></script>进行引入,commonChunkPlugin可以办到.利用commonChunkPlugin来配置多个<script></script> 引用时,可以如下配置: new webpack.optimize.CommonChunkPlu

1、webpack加载配置打包.vue文件笔记

一.创建一个初始化一个npm项目,然后一直回车选择默认 在终端输入npm init 回车选择默认值,会出现一个package.json文件然后就可以安装需要的包 二.安装需要的包 由于是一个小dome,我们来简单配置一下vue 输入: npm i webpack vue vue-loader 然后会出现WARN npm WARN [email protected] requires a peer of [email protected]* but none is installed. You m

webpack配置:css文件打包和JS压缩打包

一.CSS文件打包 1.在src下新建css文件,在css文件下新建index.css文件,输入以下代码 body{ color:red; font-size:20px; } 2.css建立好后,需要引入到入口文件,这里我们引入到index.js中 import css from './css/index.css'; document.write("It works."); 3.在终端安装style-loader和css-loader 4.安装好后,我们开始在webpack.confi

webpack配置:less文件打包和分离

一.less文件打包和分离 1.要使用less,首先使用npm安装less服务:还需要安装Less-loader用来打包使用. npm install less --save-dev npm install less-loader --save-dev 2.在module中配置 { test: /\.less$/, use: [{ loader: "style-loader" },{ loader: "css-loader" },{ loader: "le

webpack安装、入口文件

1.安装webpack 和webpack-cli //创建webpack文件夹,并进入该文件夹内 cd webpack npm init npm install webpack webpack-cli --save-de 安装完成后会自动生成node_modules文件和package.json文件,在package.json包文件中,标记了webpack和webpack-cli的版本 2.单文件打包,创建index.html文件,并引入webpack构建的js文件 3.创建src文件夹,并在s

C#ASP.NET打包安装部署文件一键安装网站,包括IIS站点创建、数据库附加。

最近在开发web网站安装部署,以前从来没有做过web的安装打包没有头绪就开始上网查资料. 查了两天资料发现网上的资料要么不全要么就有错误,我就总结了网上的资料重新整理的一番,经过本人测试可用无错误 一下为借鉴部分资料的原文地址 此链接为打包ASP.NET网站资料(这个资料有问题,在自定义操作哪一步详情看下面文章):http://www.cnblogs.com/fish520/archive/2016/09/22/5882450.html 此链接为创建IIS站点(其中代码不全我还借鉴的部分其他论坛

webpack渐入佳境系列一:webpack环境配置与打包基础【附带各种 &quot;坑&quot; 与解决方案!持续更新中...】

首先介绍传统模块化开发的主流方案: 1.基与CMD的sea.js,玉伯提出的解决方案,据说原来京东团队在使用.用时才定义,就近加载.最近在浏览seajs官方文档时发现seajs的域名已经在转卖,惊恐万分之余又想起了那句话,国内团队开发的技术,不是十全九美的最好不要用.国内高强度的生活节奏与压力使得日常维护变得很吃力.(想到这里,不禁为vue捏了一把汗,不过还好vue的前景非常光明!). 2.基于AMD的require.js,之前在用.提前声明与定义.国外团队维护. 3.基于commonJS的we

webpack安装配置使用教程详解

webpack安装配置使用教程详解 www.111cn.net 更新:2015-09-01 编辑:swteen 来源:转载 本文章来为各位详细的介绍一下关于webpack安装配置使用教程吧,这篇文章对于不喜欢使用 jspm测试的朋友可以参考一下. webpack 入门 目录 1 安装 webpack2 初始化项目3 webpack 配置4 自动刷新5 第三方库6 模块化7 打包.构建8 webpack 模板我最近大量使用的是 jspm,但因为用它搭建的前端开发环境中,写测试代码非常困难,而项目又

webpack安装教程及实例

在控制台输入: npm install webpack -g 这是全局的安装,如果需要局部安装,在控制台cd 打开到指定目录,输入: npm install webpack --save-dev 即可. 实例: 建立index.html文件 建立main.js文件 建立webpack.config.js文件 index.html <html lang="en"> <head> <title></title> <meta charse