使用Vue.js从零构建GitHub项目浏览器

最近几个月在学习Vue.js并把它应用到实际项目中,在通读官方中文教程之后,前期学习期间Create a GitHub File Explorer Using Vue.js这篇文章给我了较好的启发。于是结合自己最新的学习成果写下这篇总结。

源码地址:github-file-explorer

See DEMO

开发环境搭建

参考官方教程构建大型应用中提到的脚手架工具vue-cli,我初次了解到了webpack,vue-cli是一个简单的脚手架,可以帮助你快速地构建 Vue 项目:单文件 Vue 组件,热加载,保存时检查代码,单元测试等功能。vue-cli中有五个模板,我想用webpack-simple模板作为demo的开发环境再好不过了。

$> npm install vue-cli -g

创建第一个Vue应用

$> vue init webpack-simple github-file-explorer

$> cd github-file-explorer

$> npm install

$> npm run dev
打开浏览器,输入http://localhost:8080

Boom,你会发现我们创建的第一个Vue应用启动了。

更改默认端口

webpack-simple集成了webpack-dev-server,默认启动的端口为8080,端口容易冲突。

翻阅文档,修改配置文件package.json,更换端口为8090

"scripts": {
"dev": "webpack-dev-server --inline --hot --port 8090",
"build": "cross-env NODE_ENV=production webpack --progress --hide-modules"
},

热重载

webpack结合vue-loader以及vue-hot-reload-api实现了热重载,让开发体验极速提升。保存秒级更新,再也不用reload浏览器了。那些年我们都习惯了F5。

组件化开发体验

  1. 项目结构

  2. 引入资源

  3. 简单vue指令的使用

  4. 计算属性

  5. 数据观察

  6. 组件间数据传递

项目结构

引入资源

在index.html中引入资源,采用jsdelivrCDN加速。

简单vue指令的使用

  1. v-model 表单控件绑定

  2. v-if 根据表达式的值的真假条件渲染元素

  3. v-for 列表渲染

  4. @click 是v-on:click的简写,绑定事件监听

计算属性

computed可以对Vue实例上的数据进行再计算,根据需求,再次拼接fullRepoUrl。

fullRepoUrl: function() {
return this.username + '/' + this.repo;
}

数据观察

watch可以观察每一个Vue实例上的数据变动。当数据发生变化的时候会触发方法。通过这个机制我们可以实现更换repo来触发列表更新。

watch: {
repo: function(newVal, oldVal) {
this.path = '/';
this.getFiles();
}
}

组件间数据传递

组件(Component)是Vue.js最强大的功能之一。

在官方教程中组件占了绝大部分内容,说明组件在Vue中占有很重要的地位。

下图是我对github-file-explorer构建的简单组件链

main.js,是Vue的根实例,它扩展了App.vue作为父组件。

import Vue from 'vue'
import VueResource from 'vue-resource'
import App from './App.vue'

Vue.use(VueResource)

new Vue({
el: 'body',
components: { App }
})

  1. A,App作为父组件,建议App中不写业务逻辑,作为应用的layout,根据需求,做一个布局。比如:Header/Container/Sidebar

  2. B,Github是App组件的子组件,同时也是FileExplorer组件的父组件,实现form表单获取github文件API列表。

  3. C,FileExplorer组件为Github组件的子组件,实现列表清单。

组件关系:App > Github > FileExplorer

父组件与子组件间通讯(使用Props传递数据):

组件实例的作用域是孤立的。这意味着不能并且不应该在子组件的模板内直接引用父组件的数据。可以使用 props 把数据传给子组件。

父组件Github通过动态绑定Props向子组件传递数据

子组件FileExplorer通过Props接收父组件传递的数据

props: {
username: {
type: String,
required: true
},
repo: {
type: String,
required: true
}
},

使用Vue插件

vue-resource,通过 XMLHttpRequest 或 JSONP 发起请求并处理响应

通过vue-resource请求github的API

getFiles: function() {
this.$http.get('https://api.github.com/repos/' + this.fullRepoUrl + '/contents' + this.path,
function(data) {
this.files = data;
}
);
}

使用Vue Devtools提升开发效率

下图是对github-file-explorer组件链作用域的简单演示

Vue Devtools可以大大提升Vue应用的调试效率,再也不用{{ $data | json }}
打印调试数据了,并且它还可以调试Vuex,当你在使用Vuex时候可能对数据流转很困惑。那么使用Vue DevTools中的Vuex调试工具可以解决你的烦恼。关于Vuex的使用后续我会再写篇文章总结下,很好用的状态管理插件。不过Vue Devtools目前只有Chrome。意味着你只能在Chrome浏览器中才能使用Vue Devtools。

最终效果图

原文:使用Vue.js从零构建GitHub项目浏览器

关键字:vue.js, Github, demo

版权声明

本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部