【图文】Webpack+vue+element-ui逐步搭建开发环境

在搭建整个环境之前,首先默认你已了解了node.js、npm(cnpm)【注:npm与cnpm使用方式一样,npm是国外镜像,下载速度较慢。cnpm是国内镜像,下载速度相对快些。】、webpack、vue、element相关的基础知识。如不了解,请先阅读以下文档:

Node.js
Npm/cnpm
Webpack
Vue
element

有了以上的认识与基础知识,就可以开始搭建整个开发环境了。下面分别以纯手动搭建与用veu的脚手架vue-cli搭建。

一、纯手动搭建

如果你本地已安装了node与npm请直接路过第一二步。

第一步:

检查本地环境是否安装了node。在命令窗口下键入node -v,如果有提示版本信息表示已安装(如图1),否则安装node环境。下载地址:http://nodejs.cn/download/

图1

第二步:

检查本地环境是否安装了npm(一般node都自带了npm),在命令窗口键入npm -v,如果有提示版本信息表示已安装(如图2),否则安装npm(此处省略)。
cnpm的安装:在命令行窗口键入以下命令

npm install -g cnpm --registry=https://registry.npm.taobao.org

安装成功后就可以与npm一样的使用了,只是将npm换成cnpm即可。

图2

第三步:

有了以上两步必要的环境就可以安装webpack了。

1、首先全局安装,在命令窗口下键入以下命令:
npm install -g webpack

安装成功与否可以键入webpack -version来查看,如图3


图3
2、其次是安装到你的项目目录。你的项目目录结构由你定,图4为我所建的项目目录结构:
图4

目录结构描述:

test: 项目名称
src: 放写好的组件及其其它资源
     App.vue: vue组件
     main.js : 入口js文件
index.html : html文件
webpack.config.js: webpack配置文件

以上目录结构为最基础的目录结构,至于里面的配置及用法后面将会一一讲解。
手动建立好项目目录结构后就可以在该项目中安装webpack了。

3、在当前目录根目录下打开命令窗口,键入以下命令,将webpack安装到项目中。
npm install --save-dev webpack

此时会在项目根目录生成一个node_modules文件夹,如图4。此后所有的依赖工具包都会安装到这个文件夹下。

图4
4、生成npm安装包依赖关系配置文件,在此项目目录下命令行窗口键入以下命令:
npm init

按提示填入相应信息,也可以一步步跳过,最后会在根目录生成一个package.json文件。如下图5所示:

图5

生成好文件后修改配置文件,将scripts 里的test替换成如下图6所示

图6

下次我们就可以直接在命令行键入

npm run dev

命令来启动了。

打开webpack.config.js文件,配置入口文件与出口文件,如图10的entry与output。main.js可以什么也不用写,index.html引入配置好的出口文件的js。如下图7

图7

到此时,webpack的最小环境已搭建完毕,在命令行键入npm run dev 。打开浏览器,地址栏输入http://localhost:8080你将会看到hello world。(注:如果报端口冲突,可以修改scripts ,如: "dev": "webpack-dev-server --open --hot --port 8081" ;如果不能启动,根据报错提示查看是否还有依赖包没有安装,如有,则用

npm install --save-dev 包名 

命令安装需要的包。)

但想要开发项目还远远不够。因为你编写的css、js(ES6)等webpack还无法识别,所以得先把其依赖的编译工具包引入到webpack项目中来。以下将讲解各个工具模块的安装及其作用。

第四步:

安装Vue(如果不用vue开发当然不用安装)
在命令窗口键入如下命令下载vue 模块:

npm install --save vue

下载完成后会将vue下载到node_modules 目录下,同时会在package.config文件的 dependencies下加入vue模块。如下图8所示:


图8

第五步:

1、安装相关的loader

需要安装的loader如下(可能不止这些,如果报错根据报错提示安装缺少的包):
vue-loader : 装载vue
vue-html-loader : 由于html页面有许多vue 的标签,所以需要引入这个loader才能识别。
css-loader : 装载css
style-loader : 装载style
vue-hot-reload-api : 热重载Vue组件的API
vue-template-compiler : 装载vue模板
如果要使用ES6语法,还需要安装babel(简单简介:babel就是将高版本的js语法编译成低版本语法的工具包)。Babel相关的loader 如下:
babel-loader
babel-core
babel-plugin-transform-runtime
babel-preset-es2015
babel-runtime
安装方式与上面安装vue一样,使用npm或是cnpm,安装可以一次性跟多个,如

cnpm install --save-dev  vue-loader  vue-html-loader 等

注:其中--save-dev 与 --save的区别是:--save-dev会将安装包信息写入package.config文件里的devDependencies里,--save会将安装包信息写入dependencies里。至于区别,顾名思义。

如果你的项目还用到其它loader,直接npm下载安装即可。
安装完以上工具后package.config文件如下图9所示


图9

现在,webpack+vue要使用到的工具都已准备完毕了,但还不能开发vue的项目,因为只是下载下来而已,还需要配置webpack.config.js后才真正算是搭建完毕。

2、配置webpack.config.js,如图10
图10-1

图10-2

到此,webpack+vue的环境就搭建完毕。下面将介绍怎么使用vue开发。

将index.html页面改成如下图11


图11

<my-app></my-app>表示引用了一个vue的组件,但它是怎么渲染出来的,请看如下图12的main.js


图12

上面的代码表示,引入了vue模块vue的组件模块,接下来这个页面就有了vue的所有环境,new Vue()里写自己的逻辑就行了。下面再来看App.vue模块怎么写的,如下图13

图13

Vue的模板有三部分组成,template、style、script。至于怎么写,这里就不说明了。

好了,现在,在命令窗口键入以下命令:

npm run dev

打开浏览器输入http://localhost:8080,如果没有报错,你将会看到hello world。如果报错,在代码及配置没出错的情况下可能出现的原因是lorder不全,下载的版本不兼容等。

第六步:

安装element
与之前一样,npm下载element
命令窗口键入以下命令:

npm i element-ui -S

安装file-loader
命令窗口键入以下命令:

npm install --save-dev file-loader

下载完成后就可以使用element的组件了。
下面,我将介绍如何在index.html页面中使用element不同的组件。首先,下载 babel-plugin-component,在命令窗口键入以下命令:

npm install babel-plugin-component -D

然后,将 .babelrc 修改为(如果没有该文件则手动创建,用开发工具创建):

{
  "presets": [
    ["es2015", { "modules": false }]
  ],
  "plugins": [["component", [
    {
      "libraryName": "element-ui",
      "styleLibraryName": "theme-default"
    }
  ]]]
}

比如,index.html页面使用到element的TimePicker 时间选择器
及Cascader 级联选择器。

首先,新建两个vue模板TimePicker.vue、Cascader.vue。打开官网,将TimePicker与Cascader相关的组件代码copy到两个文件里(注意:vue的组件是由template、style、script三部分组成的,如果copy的组件代码部分没有template标签,则要自己加上去,而且最外层还应由一个div包裹。)。Enement ui官网:

http://element.eleme.io/#/zh-CN/component/installation

其次,打开main.js,改为如下图14所示:

图14

再次,在index.html里引用这两个组件,如下图15:


图15

好了,现在,打开命令窗口键入如下命令:

npm run dev

打开浏览器,你将看到,两个组件已加载到了页面中。

至此,整个webpack+vue+element的开发环境就搭建完了,至于后面需要用到路由,ajax请求之类的组件时按上面的方式安装使用就是。

第七步:

部署到生产环境。
现在,你也许会问,我要放在生产环境怎么办呢?好,下面将介绍如何将你写的代码部署到生产环境。
首先,修改package.json文件,在scripts位置加如图16的配置:


图16

在命令窗口输入以下命令:

npm run build

执行命令后,将会生成你webpack.config.js里配置的输出文件dist/build.js。
好了,现在,你只需把index.html页面与dist文件夹copy到你的生产服务器上就OK了。至于你的web服务器使用的是tomcat或是apache或是其它的都无所谓,就看你自己的需求了。

二、使用vue-cli脚手架搭建

如果你觉得上面手动搭建太麻烦,还好,vue提供了一种方式可以快速的搭建好webpack+vue的开发环境。下面将介绍如何使用vue-cli脚手架搭建环境。

第一步:

与安装其它模块一样,vue-cli也是一种工具模块,打开命令窗口,键入以下命令:

npm install vue-cli -g

这是全局安装,如果npm安装时间较长换成cnpm。安装完成后,就可以使用脚手架搭建环境了。

第二步:

vue-cli提供了几种模板,如下三种模式:
Simple(太简单,就一个index.html文件)、webpack-simple(比较实用)、webpack(较全,内置有方法检查、单元测试等。)
我这里只讲解webpack-simple模式,如果对其余两种感兴趣可以自己尝试。
在你要放项目的目录打开命令窗口,键入以下命令:

vue init webpack-simple 项目名

安装完毕,在目录下会生成你的项目结构,项目结构如下图1:


图1

上面文件与我们手动创建的没啥区别,是不是很简单?但是,现在整个项目还不能跑起来,因为所有的第三方工具都还没下载呢,所以还需要安装项目所依赖的工具包。

第三步:

在项目根目录打开命令窗口,键入以下命令:

npm install

输入这个命令程序会自动下载package.config下所依赖的工具包。耐心等待下载完毕,到此,webpack+vue的环境就搭建好了。

第四步:

现在element组件还没有引入进来,我想到此你已经知道如何引入element组件了,如还不明白,请参考手动搭建。其余的工作与上面手动搭建完全一样,这里就不必多说了。

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

推荐阅读更多精彩内容