github repo
An exemplary real-world application built with Vue.js, Vuex, axios and different other technologies. This is a good example to discover Vue for beginners. demo
起步
git clone https://github.com/gothinkster/vue-realworld-example-app.git
cd vue-realworld-example-app
npm install
npm run dev #会在自动打开浏览器跳转到localhost:8080
分析
项目结构
data:image/s3,"s3://crabby-images/c0e84/c0e84520fdcd3646d75941b95d067bdcd20d58a6" alt=""
data:image/s3,"s3://crabby-images/0dcfa/0dcfada9e2930fddd8f77a105f0616a56232bf45" alt=""
src
App.vue是主组件,在这里面引入其他组件,达到模块化的目的。
main.js中初始化Vue实例。
还剩下common
,components
,router
,store
,views
五个文件夹
common中有5个js文件
api.service.js
中初始化了几个api服务:ApiService
、TagsService
、ArticlesService
、CommentsService
。方便后面在组件中使用CRUD(creat, retrieve, update, delete)操作。
config.js
中配置了API_URL,即后端api的地址,默认是官网demo的后端,可以改成本地运行的后端api地址
date.filter.js
和error.filter.js
做的是数据的格式化
jwt.service.js
中封装了对window.localStorage的三种基本操作: getItem
、setItem
、removeItem
以处理token
store文件夹中是vuex的一些配置文件
分为home,auth,article,profile四个模块,每个模块导出四项
data:image/s3,"s3://crabby-images/53c80/53c8018e7d4d34cf7241b33c8bf80c7325e0e169" alt=""
data:image/s3,"s3://crabby-images/5b781/5b781680cb9021631e244a3a7e2de8de4bbcfe02" alt=""
actions.type.js
和 mutations.type.js
中定义了各模块中用到的action和mutationdata:image/s3,"s3://crabby-images/71aee/71aee2b768fe2d38af22b4a6b7b8404f770b0d41" alt=""
data:image/s3,"s3://crabby-images/206aa/206aa3bf15d7f31671032e528255ee4f7c454e23" alt=""
index.js
中初始化了Vuex
todo分析一个具体的模块
views
<!-- App.vue -->
<template>
<div id="app">
<rwv-header></rwv-header>
<router-view></router-view>
<rwv-footer></rwv-footer>
</div>
</template>
<script>
import RwvHeader from '@/components/TheHeader'
import RwvFooter from '@/components/TheFooter'
export default {
name: 'App',
components: {
RwvHeader,
RwvFooter
}
}
</script>
<style>
</style>
可以看到主模块中除了引入了header和footer两个模块还有一个<router-view></router-view>
它的作用就是根据 router/index.js
里面定义的路由规则把在此处渲染相应的模块
比如访问/login
会加载views/Login
模块,即views/Login.vue
data:image/s3,"s3://crabby-images/6ee53/6ee53e23f791b4ddd70b1963fb4819006fb2929b" alt=""
显然,
views
文件夹内的文件都对应着某条路由规则,可以结合着看,顺着路由找组件。
components
components
文件夹下是一个个组件,作为螺丝钉🔩,被views
里的组件使用
data:image/s3,"s3://crabby-images/f7706/f77063bd6a87deb6f8415629a07dfdbd414735a9" alt=""
网友评论