使用路由建立多视图单页应用(SPA)

         今天给大家分享一下  组件或者路由间的跳转,vue中文件及文件夹命名规范  希望大家能够喜欢,如果那里讲的不对,欢迎大家评论指明。

1.vue中文件及文件夹命名规范

  1. 命名法
    驼峰式命名法(camelCase)
    短横线命名(kebab-case)全小写
    帕斯卡命名法(PascalCase)

  2. 文件夹命名
    kebab-case
    尽量使用名词,尽量使用一个单词

  3. *.js文件命名规范
    3.1 所有模块的主文件index.js全小写
    3.2 属于组件的.js文件,使用PascalBase风格
    3.3 其他类型的.js文件,使用kebab-case风格

  4. *.vue文件命名规范
    除index.vue之外,其他.vue文件统一用PascalBase风格

kebab-case        短横线命名也被称为巴西烤串

1.2 SPA简介

单页Web应用(single page application,SPA),就是只有一个Web页面的应用,只加载单个HTML页面,并在用户与应用程序交互时动态更新该页面的Web应用程序

简单来说,就是加载页面时,第一次加载页面时,将所有HTML缓存到内存上,下次加载页面时        只需要加载数据就好了;

实现案例       组件或者路由间的跳转

  • 单页面应用程序:
    只有第一次会加载页面, 以后的每次请求, 仅仅是获取必要的数据.然后, 由页面中js解析获取的数据, 展示在页面中

  • 传统多页面应用程序:
    对于传统的多页面应用程序来说, 每次请求服务器返回的都是一个完整的HTML页面

  • 优势
    减少了请求体积,加快页面响应速度,降低了对服务器的压力
    更好的用户体验,让用户在web app感受native app的流畅

2. 创建一个路由实现组件之间跳转

2.1 引入依赖库

建立一个基本html项目,创建一个demo页面并引入一下js库文件

  • <script src="js/vue.js"></script>
  • <script src="js/vue-router.min.js"></script>(路由SAP管理器的js)

2.2 创建自定义组件

创建vue组件有两种方式:

  • var MyComonent = Vue.component("button-counter", {...});
    创建一个vue组件并赋给MyComponent变量
  • const Home = Vue.extend({});(当前使用)
    extend是构造一个组件的语法器. 你给它参数,他给你一个组件,然后这个组件你可以作用到Vue.component这个全局注册方法里,也可以在任意vue模板里使用

2.3 什么是路由

vue的单页面应用是基于路由和组件的,路由用于设定访问路径,并将路径和组件映射起来。
传统的页面应用,是用一些超链接来实现页面切换和跳转的。在vue-router单页面应用中,则是路径之间的切换,实际上就是组件的切换。
路由就是SPA(单页应用)的路径管理器。再通俗的说,vue-router就是我们WebApp的链接路径管理系统。

route和router的区别

  • route:路线
  • router:路由器
  • 路由器中包含了多个路线

案例:组件间的组件跳转

1 创建一个Home组件和About组件

//组件名用PPascalCase风格
const Home = Vue.extend({
    //必须定义一个根元素作为容器,包裹模板中的内容元素
    template: '<div><h1>Home组件</h1><div>Home组件内容区</div></div>'
});

const About = Vue.extend({
    //必须定义一个根元素作为容器,包裹模板中的内容元素
    template: '<div><h1>About组件</h1><div>About组件内容区</div></div>'
});

2 定义路由

定义路由 

  • "/"代表根路径
  •  path:跳转路由路径
  • component:配置指定路由
//定义路由,"/"代表根路径,路由中可以使用name属性,一遍情况不建议使用
var routes = [
    {path: '/home',component: Home},
    {path: '/about',component: About}
];

//创建路由器实例
const router = new VueRouter({
    routes: routes
});

3 创建和挂载根实例

使用路由后,Vue实例的创建于以前会有一定的区别,原来使用el属性指定边界

//创建和挂载根实例
var vm = new Vue({
    el: '#app',
     //将路由放入vue实例
    router: router,
    data: {
        ts: new Date().getTime()
    }
});

4 使用RouterLink和RouterView组件导航与显示

<div>
    <router-link to="/home">go to Home</router-link>
    <router-link to="/about">go to aboue</router-link>
</div>
<div>
     <router-view></router-view>
</div>

<router-view></router-view>路由内容显示区域。

效果展示

 如图所示,如果点击gt to home  跳转到Home组件中,如果点击go to about    跳转到About组件中

 

router-link相关属性

4.1 to

表示目标路由的链接 上面的示例已经使用,to既可以使用字符串,也可以使用js表达式

<router-link to="/home">Home</router-link><!-- 字符串-->
<router-link v-bind:to="'home'">Home</router-link><!-- 使用 v-bind 的 JS 表达式 -->

4.2 replace

设置 replace 属性的话,当点击时,会调用 router.replace() 而不是 router.push(),导航后不会留下 history 记录
样例:

<router-link :to="{ path: '/home'}" replace></router-link>

如果配置了replace,则在点击该链接,将会导致history记录被清空,不能再执行回退。

this.$router.push({    
       path:'/home'
});
//或者使用path,推荐path
this.$router.push({    
       path:'/home'
});

示例一:前进和后退实现

  • this.$router.go(-1) :代表着后退
  • this.$router.go(1):代表着前进
  • 切换到path为/home的路由
<p>
    <button @click="previous">前进</button>
    <button @click="next">后退</button>
</p

2)添加事件处理程序

methods: {
    //前进
    previous: function() {
        this.$router.go(1);
    },
    //后退
    next: function() {
        this.$router.go(-1);
    }
}

示例二:切换到指定路由 添加一个“回家”按钮。

<button @click="gotohome">回家</button>
gotohome: function() {
    console.log("go to home");
    this.$router.push({
        path: '/home'
    });
}

示例三,设置默认显示的组件
这个很简单,只要将需要默认显示的组件对应的路由的path设置为"/"即可

//定义路由表
var routes = [
    //默认显示home
    {path:'/', component:Home}, 
    {path:'/home', component:Home},
    {path:'/about', component:About}
];

示例四:
如果配置了replace,则在点击该链接,将会导致history记录被清空,不能再执行回退。
例如: 将

<router-link to="/home">Home</router-link>

加入replace属性,修改为:

<router-link to="/home" replace>Home</router-link>

通过测试可以看到,点击home后,history记录被清空。所以一般不用。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值