vue 的代码文档写的真的不忍直视,一言难尽。
而,现在网络上流行的教程都一言难尽,没有从核心-大局来进行讲解,后来,我看到了一个非常优秀的导学,所以,移植到我的博客中,供大家学习。
参考资料
什么是Vue.js
不管你想不想了解,你只需要大概知道,Vue
就是和jQuery
一样是一个前端框架,它的中心思想就是数据驱动,像远古时代的老前辈jQuery是结构驱动,什么意思呢,以前我们写代码时常用$('.dom').text('我把值改变了')
,这种写法先要获得结构,然后再修改数据更新结构,而Vue的做法直接就是this.msg="我改变了"
,然后msg就会同步到某个结构上,视图管理抽象为数据管理,而不是管理dom结构了。不懂没关系,慢慢来。
还有一点必须要知道的是,Vue是国人写的,技术文档也妥妥的是中文,想到这我就有学习的动力。
搭建环境
可以看我之前的博文。
npm install
是安装项目所需要的依赖,简单理解就是安装一些必要的插件,需要等一段时间;
npm run dev
是开始执行我们的项目了,一旦执行这个命令之后,等一小会,浏览器应该会自动帮你打开一个tab为http://localhost:8080/#/的链接,这个链接就是我们本地开发的项目主页了,如果没有,说明出错了。
(PS:开发完成后执行 npm run build
会编译我们的源代码生成最终的发布代码,在dist目录下)
你可以看我下面的博文。
目录解析
目录/文件 | 说明 |
---|---|
build | 项目构建(webpack)相关代码 |
config | 配置目录,包括端口号等。我们初学可以使用默认的。 |
node_modules | npm 加载的项目依赖模块 |
src | 这里是我们要开发的目录,基本上要做的事情都在这个目录里。里面包含了几个目录及文件: assets: 放置一些图片,如logo等。 components: 目录里面放了一个组件文件,可以不用。 App.vue: 项目入口文件,我们也可以直接将组件写这里,而不使用 components 目录。 main.js: 项目的核心文件。 |
static | 静态资源目录,如图片、字体等。 |
test | 初始测试目录,可删除 |
.xxxx文件 | 这些是一些配置文件,包括语法配置,git配置等。 |
index.html | 首页入口文件,你可以添加一些 meta 信息或统计代码啥的。 |
package.json | 项目配置文件。 |
README.md | 项目的说明文档,markdown 格式 |
我们需要关注的仅仅只有
- package.json
- 保存一些依赖信息
- config
- 保存一些项目初始化配置
- build
- 里面保存一些webpack的初始化配置
- index.html
- 是我们的首页
- src目录
- 我们的代码所在
index在很多服务器语言中都是预设为首页,像index.htm,index.php等,打开build目录中的webpack.base.conf.js
,会看到这样的代码
1 | module.exports = { |
说明我们的入口js文件在src目录中的main.js,接下来我们就分析下这些初始化代码先;
跟着代码走
Vue的核心架构,按照官方解释和个人理解,主要在于
- 组件
- 路由
两大模块,只要理解了这两大模块的思想内容,剩下API使用就只是分分钟的事情了。所以在我的系列文中,会围绕组件和路由教大家开发一个前端组件库,这个过程也是我个人学习的练手项目,个人觉得一步步做下来之后,对Vue的理解就可以算是出师了,胜过读10遍书籍文档,那是后话了,先让我们看看最基本的Vue生成的默认代码吧!
main.js
1 | // The Vue build version to load with the `import` command |
先是第一句
import Vue from 'vue'
这句很好理解,就像你要引入jQuery
一样,vue
就是jquery-min.js
,然后Vue就是$
;然后又引入了./App
文件,也就是目录中和main.js同级的App.vue文件;在Vue中引入文件可以直接用import
,文件后缀名可以是.vue
,这是Vue自己的文件类型,之前说的webpack会将js和css文件打包,同样的道理,在webpack中配置vue插件后(项目默认配置),webpack就可以将.vue类型的文件整合打包,这和nodeJs中require差不多的道理。
说回App.vue
这个文件,这是一个视图(或者说组件和页面),想象一下我们的index.html中什么也没有,只有一个视图,这个视图相当于一个容器,然后我们往这个容器中放各种各样的积木(其他组件或者其他页面),App.vue中的内容我们后面说;
import router from './router'
这句代码引入一段路由配置,同样的后边说(很快就说到的不用急)
接下来的 new Vue
实例化,其实就相当于平时我们写js时候常用的init啦,然后声明el:'#app'
,意思是将所有视图放在id
值为app
这个dom元素
中,components表明引入的文件,即上述的App.vue文件,这个文件的内容将以<App/>
这样的标签写进去#app
中,总的来说,这段代码意思就是将App.vue放到#app
中,然后以<App/>
来指代我们的#app
。
1 | import Vue from 'vue' |
单页面组件
好了,现在打开我们的App.vue文件,在Vue中,官网叫它做组件,单页面的意思是结构,样式,逻辑代码都写在同一个文件中,当我们引入这个文件后,就相当于引入对应的结构、样式和JS代码,这不就是我们做前端组件化最想看到的吗,从前的asp、php也有这样的文件思想。
App.vue
1 | <template> |
node端之所以能识别.vue
文件,是因为前面说的webpack在编译时将.vue文件中的html,js,css都抽出来合成新的单独的文件。
单页面组件会在后面的实战中完整体现,这里先不做过多描述;
看到我们文件内分为三大部分,分别是<template><script><style>
,很好理解结构,脚本,样式;
script就像node一样暴露一些接口,可以看到我们的template标签中除了一张图片之外就只有一行代码:<router-view></router-view>
1 | <template> |
回看我们的浏览器页面中,图片是有了,可下面的文本和链接的代码写在哪里了呢?这里就要开始涉及路由了。
路由
这里补充下路由的大致概念:传统的php路由是由服务器端根据一定的url规则匹配来返回给前端不同的页面代码,如以下地址
注意这里只有about和recruit,这些不带xxx.html的地址其实是服务器端经过一层封装指定到某些文件上去。同样的道理,前端也可以根据带锚点的方式实现简单路由(不需要刷新页面)
其中#mac
就是我们的锚点路由,注意开始我们在浏览器中打开的地址:
路由让我们可以访问诸如http://localhost:8080/#/about/
或者 http://localhost:8080/#/recruit
这些页面的时候不带刷新,直接展示。现在回到我们刚才打开的App.vue文件中看这行代码
<router-view></router-view>
这句代码在页面中放入一个路由视图容器,当我们访问http://localhost:8080/#/about/
的时候会将about的内容放进去,访问http://localhost:8080/#/recruit
的时候会将recruit
的内容放进去
如此看来,无论我们打开http://localhost:8080/#/about/
还是http://localhost:8080/#/recruit
页面中的图片都是公用部分,变得只是路由器里面的内容,那么路由器的内容谁来控制呢?
前面说的src/main.js
中有一句引入路由器的代码。
import router from './router'
现在就让我们打开router目录下的js文件。
1 | import Vue from 'vue' |
前面先引入了路由插件vue-router
,然后显式声明要用路由 Vue.use(Router)
。注意到Hello,About等都是页面(也可以是组件),接着注册路由器,然后开始配置路由。
路由的配置应该一目了然,给不同的path分配不同的页面(或组件,页面和组件其实是一样的概念),name参数不重要只是用来做识别用的。看到这里就可以明白,前面说的红色框的内容,其实就是Hello里面的内容,打开components目录下的Hello.vue就能明白了。
到这里就可以完成路由的配置,我个人习惯喜欢把页面放在pages目录
下,组件放在components目录
下,可能有人会问如果要访问http://localhost:8080/#/about/me
的话要如何配置呢,很简单只要给路由加多一个子路由配置,如下:
1 | { |
访问/blog的时候会访问Blog页面,Blog里面放个路由器就可以了,然后访问http://localhost:8080/#/blog/
的时候会往路由容器中放置page1
的内容,访问http://localhost:8080/#/blog/info
的时候会往路由容器中放置page2
的内容
1 | <template> |
小结
贯穿我们刚才学习的过程,从初始化到页面展示,Vue的页面架构流程大概是这样的
还是建议下载源码来看。