Skip to content

Latest commit

 

History

History
63 lines (44 loc) · 4.54 KB

File metadata and controls

63 lines (44 loc) · 4.54 KB

从零开始搭建 《vue-hackernews-2.0》

前言 [ English Version ]

欢迎大家来到我的第一个程序搭建教程: 从零开始搭建 《vue-hackernews-2.0》

作为一个前端开发的初学者,在接触学习到 Vue.js 的时候,我发现官方提供并极力推荐的项目《vue-hackernews-2.0》对于新手而言比较难理解。但同时我又被这种高度工业化的项目所吸引,所以我决定花一段时间来弄清楚这个项目到底是怎么运行起来的。 在这个教程中我将会通过利用不同的版本的迭代的方式来逐步重建这个项目。

这个项目是面向初学者的。 整个教程中,我逐步实现了这个项目的四个版本,每一个版本之间有一定的递进关系。为了方便理解掌握每个版本的内容,在每个版本的说明中,我会尽量把在相应版本中所需要掌握的知识点列出来。

注明:简便起见,如未特别说明,在之后的所有章节中我会用 Vue-HN 来代替 vue-hackernews-2.0 项目。 项目运行的系统是 Windows 7,因条件限制未在其他系统上测试,请见谅。

各版本简介

0. Vue.js, Vuex, Vue-router, HN API, Firebase, ES6

作为一个前端初学者,我对最原始的页面构造比较熟悉,也就是页面只由 HTML、CSS 以及 JavaScript 构成。所以自从我开始学习 Vue-HN 这个项目我就想是不是可以用最原始的方法来实现这个项目(当然,不考虑用户体验及性能等方面)。在经过多次失败的尝试之后,我终于只利用 Vue.js 及其生态中的一些库实现了这个版本。下面这两个动图就分别是我这个版本和官方版本。

Origin Website
[ 我的版本 ]

Plane Vue.js
[ 官方版本 ]

1. Webpack, Vue.js, Vue-router, Vuex and Hackernews API

经过第一个版本后,我们对这个项目有了初步的了解。在这个版本中,我们会使用一些工具,使得我们这个项目初步模块化,同时也更加便于维护。我们将会使用到一些基本的插件和包,并通过 webpack 来实现功能。我们只需要简单的配置一下 webpack 就行,不会涉及到服务器端的内容,不会涉及缓存也不会涉及生产模式及开发模式的不同配置。下面的动图就是这个版本的成品,同时这个动图里面还包含了对整个项目的简单解构。

Basic functions and simple deconstruction
[ 基本功能及简单解构 ]

2. Server, Packages and Plugins for Better Performance

于我而言,这个版本是整个项目中最难的一个版本。为了优化用户体验,原作者将很多因素考虑在内,这就会带来很多需要了解的新知识,比如 node.js 中的 express 框架以及各种插件。服务器端及客户端、生产模式及调试模式的不同配置是这个版本的重点。在接下来的片段中,我会将我所理解的部分分享给大家。 由于这个版本和官网的一样,我就不上效果图了。

3. Change the Project as I like

在这个版本中,我将会根据自己的喜好对整个网页进行一些改造,使得网页整体更具有 Vue.js 风格,至少从视觉上来说更加的 Vue.js。下面的动图可以预览到我这个版本的成品,为了对照官方例子,你可以去官网查看原网页。对于所添加及更改的部分,本节的下半部分将会详细介绍。

Last Edition of Vue-HackerNews
[ Vue-HackerNews 最后版本 ]

目录

0-vue.js-vuex-router-firebase-ES6
1-webpack-vue.js-router-store-firebase
2-Packages-Plugins-for-Better-User-Experience
3-Change-the-Project-as-I-like

License

Copyright (c) 2017 Copyright Holder All Rights Reserved.
MIT (http://opensource.org/licenses/mit-license.php)