接上文,src文件夹是项目核心文件夹,所有的代码都放在这个文件夹下面。
代码结构如下:
hello-world
|
|-- public
|-- |-- favicon.ico //网站图标
|-- |-- index.html //入口页面
|-- src
|-- assets // 静态文件,比如一些图片,json数据等
| |-- components // vue公共组件
|-- views // 以页面为单位的vue文件、html文件等
| |-- App.vue // 页面入口文件
| |-- main.js // 程序入口文件,加载各种公共组件
| |-- router.js // vue的路由管理
| |-- store.js // vuex
1)App.vue
App.vue类似于一般网站的母板页,App.vue中包含导航(<router-link>
)和子视图(<router-view>
),通过点击导航切换子视图的主体内容,子视图一般会放在views文件夹下。代码如下:
<template>
<div id="app">
<div id="nav">
<!-- 使用 router-link 组件来导航. -->
<!-- 通过传入 `to` 属性指定链接. -->
<!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
<router-link to="/">Home</router-link> |
<router-link to="/about">About</router-link>
</div>
<!-- 路由出口 -->
<!-- 路由匹配到的组件将渲染在这里 -->
<router-view/>
</div>
</template>
<style lang="less">
。。。
</style>
<router-link>
组件支持用户在具有路由功能的应用中 (点击) 导航。 通过to
属性指定目标地址,默认渲染成带有正确链接的<a>
标签,可以通过配置tag
属性生成别的标签.。
<router-view>
组件是一个 functional 组件,渲染路径匹配到的视图组件。
2)main.js——程序入口
import Vue from 'vue';
import App from './App.vue';
import router from './router';
import store from './store';
Vue.config.productionTip = false;
new Vue({
router,
store,
render: h => h(App),
}).$mount('#app');
因为我们前面的章节并不会涉及到状态管理,因此暂时注释掉对store的调用:
import Vue from 'vue';
import App from './App.vue';
import router from './router';
Vue.config.productionTip = false;
new Vue({
router, //(缩写) 相当于 router: router
render: h => h(App),
}).$mount('#app');
实例化Vue,传入两个属性 router和render。这里因为我们通过import引入的router和属性名重名了,造成预期的属性需要缩写。如果写成router: router,eslint会提示这一行代码有坏味道,因为您本可以使用缩写的,如下:
Module Warning (from ./node_modules/eslint-loader/index.js):
error: Expected property shorthand (object-shorthand) at src\main.js:9:3:
7 |
8 | new Vue({
> 9 | router: router,
| ^
10 | render: h => h(App),
11 | }).$mount('#app');
这里我们索性再搞一个重名,实例化的时候,把两个属性都用缩写,最终的代码如下:
import Vue from 'vue';
import App from './App.vue';
import router from './router';
Vue.config.productionTip = false;
const render = h => h(App);
new Vue({
router,
render,
}).$mount('#app');
脚手架在router.js文件中定义路由
import Vue from 'vue';
import Router from 'vue-router';
import Home from './views/Home.vue';
Vue.use(Router);
export default new Router({
mode: 'history',
base: process.env.BASE_URL,
routes: [
{
path: '/',
name: 'home',
component: Home,
},
{
path: '/about',
name: 'about',
// route level code-splitting
// this generates a separate chunk (about.[hash].js) for this route
// which is lazy-loaded when the route is visited.
component: () => import(/* webpackChunkName: "about" */ './views/About.vue'),
},
],
});
并在main.js通过import引入,
import router from './router'
这里,为了便于讲解,我们把这行代码去掉,将rouer.js中的实现拿过来,直接放到main.js里,将这两个文件合二为一:
import Vue from 'vue';
import Router from 'vue-router';
import Home from './views/Home.vue';
import App from './App.vue';
Vue.config.productionTip = false;
Vue.use(Router);
// 1. 定义路由
// 每个路由应该映射一个组件。 其中"component" 可以是
// 通过 Vue.extend() 创建的组件构造器,
// 或者,只是一个组件配置对象。
const routes= [
{
path: '/',
name: 'home',
component: Home,
},
{
path: '/about',
name: 'about',
component: () => import('./views/About.vue'),
},
];
// 2. 创建 router 实例,传入上面定义的 `routes` 配置
const router = new Router({
mode: 'history',
base: process.env.BASE_URL,
routes: routes,
});
// 3.通过render渲染主组件App
const render = h => h(App);
// 4. 创建和挂载根实例。
// 通过 router 配置参数注入路由,从而让整个应用都有路由功能
new Vue({
router,
render,
}).$mount('#app');
现在就可以很容易的弄清整个实例化过程了。
通过代码,我们可以了解到main.js大致的功能:
main.js通过import将一个Vue.js的组件文件引入,并创建一个Vue实例,在构造函数中,通过 router 配置参数注入路由,从而让整个应用都有路由功能,用render配置参数来绘制App主组件,并将实例化后的Vue挂载到index.html中的 <div id="app"></div>这个dom元素。
现在应用就可以启动了。