博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
webpack入坑之旅不是开始的开始
阅读量:4083 次
发布时间:2019-05-25

本文共 2641 字,大约阅读时间需要 8 分钟。

  • 最近学习框架,选择了vue,然后接触到了vue中的单文件组件,官方推荐使用 Webpack + vue-loader构建这些单文件 Vue 组件,于是就开始了webpack的入坑之旅。
    因为原来没有用过任何的构建工具与模块化工具,所以本系列会十分的基础。并且可能有很多不正确的地方,希望大家谅解,并指出错误帮助改进。谢谢!
    转自个人博客:

    这是一系列文章。此系列所有的练习都存在了我的github仓库中,在本人有了新的理解与认识之后,会对文章有不定时的更正与更新。下面是目前完成的列表:

    什么是webpack

    其实不是特别想写这个东西,但貌似所有的教程都有这个。随便写两句吧。可以直接跳过。

    Webpack 是德国开发者 Tobias Koppers 开发的模块加载器兼打包工具,在webpack中,它能把各种资源,例如JS(含JSX)、coffee、样式(含less/sass)、图片等都作为模块来使用和处理。因此, Webpack 当中 js 可以引用 css, css 中可以嵌入图片 dataUrl。
    对应各种不同文件类型的资源, Webpack 有对应的模块 loader比如vue用的是vue-loader当然这是后话,在后面我们再来说。

    请看下图:

    官网查看:

    安装

    前提:因为webpack是一个基于node的项目,所以首先需要确保你的电脑里面已经安装了node.js,以及npm。在这里我使用的版本是:node:v5.8.0 ,npm:3.7.3,若是版本问题,请更新到最新版。
    若是有出现npm安装过慢的情况,可以使用这个项目来进行npm源地址的切换。

    首先我们直接进行全局的安装,运行如下命令:npm install webpack -g,可能需要一点时间。

    安装成功后,在命令行输入webpack -h即可查看当前安装的版本信息。以及可以使用的指令。

    当然,我们都应该将webapck安装到当前的项目依赖中,此时就可以使用项目的本这样就可以使用项目本地版本的 Webpack。

    # 确保已经进入项目目录# 确定已经有 package.json,没有就通过npm init # 创建,直接一路回车就好,后面再来详细说里面的内容。# 安装 webpack 依赖npm install webpack --save-dev# 简单的写法:-_-,缩写形式 npm i webpack -D# –save:模块名将被添加到dependencies,可以简化为参数-S。# –save-dev: 模块名将被添加到devDependencies,可以简化为参数-D。

    安装好之后我们的package.json的目录应该是这样的:

    {  "name": "first-demo",  "version": "1.0.0",  "description": "this is my first-demo",  "main": "index.js",  "scripts": {    "test": "echo \"Error: no test specified\" && exit 1"  },  "author": "guowenfh",  "license": "MIT",  "dependencies": {},  "devDependencies": {    "webpack": "^1.12.14"  }}

    既然环境都已经安装好了,那么我们就开始来用webpack进行我们的第一个打包运行程序吧!

    首先创建一个静态页面 index.html 和一个 JS 入口文件 entry.js,(这里你想用什么名字都可以,只需要在打包的时候读取文件为该名字就好,不过,到时候就知道这个名字的含义啦!):

    /*** entry.js ***/document.getElementById('app').innerHTML="这是我第一个打包成功的程序";

    文件都已经创建成功了,那么就开始我们的打包吧!

    webpack entry.js bundle.js

    在浏览器中打开index.html,就能看到我们设置的文字啦!:这是我第一个打包成功的程序

    这么简单的功能直接在html中引入不就好了吗?确实是这样的,不过我们这才刚刚开始嘛,不要急。

    下面我们再来增加一个文件,名为first.js内容如下:

    var h2= document.createElement("h2")h2.innerHTML="不是吧,那么快第二个打包程序啦!";document.body.appendChild(h2);

    更改 entry.js:

    document.getElementById('app').innerHTML="这是我第一个打包成功的程序";//添加require("./first.js");

    再来进行一次重复的工作,再打包一次。webpack entry.js bundle.js,如果成功,打包过程会显示日志:

    Hash: b1cfe7ff9d75ce235dc9Version: webpack 1.12.14Time: 54ms    Asset     Size  Chunks             Chunk Namesbundle.js  1.82 kB       0  [emitted]  main   [0] ./entry.js 208 bytes {0} [built]   [1] ./first.js 145 bytes {0} [built]

    Webpack 会分析入口文件,解析包含依赖关系的各个文件。这些文件(模块)都打包到 bundle.js 。Webpack 会给每个模块分配一个唯一的 id 并通过这个 id 索引和访问模块。在页面启动时,会先执行 entry.js 中的代码,其它模块会在运行 require 的时候再执行。

    刷新浏览器,可以发现我们的刚刚的代码已经生效,又有了新的文字出现。

    好吧,我知道这么简单的你们不屑于看,等下我们升个级。

    下面是参考文档,也相当于一个汇总吧,有很多我还没实践到,还是可以多看看,好文章应该贴出来

    •  还没敲呢,应该全部敲一遍的。

  • https://segmentfault.com/a/1190000004690338

转载地址:http://gweni.baihongyu.com/

你可能感兴趣的文章
eureka-client.properties文件配置
查看>>
MODULE_DEVICE_TABLE的理解
查看>>
platform_device与platform_driver
查看>>
platform_driver平台驱动注册和注销过程(下)
查看>>
.net强制退出主窗口的方法——Application.Exit()方法和Environment.Exit(0)方法
查看>>
c# 如何调用win8自带的屏幕键盘(非osk.exe)
查看>>
build/envsetup.sh 简介
查看>>
linux怎么切换到root里面?
查看>>
安装alien,DEB与RPM互换
查看>>
编译Android4.0源码时常见错误及解决办法
查看>>
Android 源码编译make的错误处理
查看>>
linux环境下C语言中sleep的问题
查看>>
ubuntu 12.04 安装 GMA3650驱动
查看>>
新版本的linux如何生成xorg.conf
查看>>
xorg.conf的编写
查看>>
启用SELinux时遇到的问题
查看>>
virbr0 虚拟网卡卸载方法
查看>>
No devices detected. Fatal server error: no screens found
查看>>
新版本的linux如何生成xorg.conf
查看>>
Centos 6.0_x86-64 终于成功安装官方显卡驱动
查看>>