Vue 编程式路由导航

news/2024/7/24 3:48:53 标签: vue

文章目录

  • router- link的replace属性
  • 编程式路由导航
  • 缓存路由组件
  • 两个新的生命钩子

router- link的replace属性

1.作用:控制路由跳转时操作浏览器历史记录的模式
2.浏览器的历史记录有两种写入方式:分别为pushreplacepush是追加历史记录,replace是替换当前记录。路由跳转时候默认为push
3.如何开启replace模式<router-link replace .......>News</router-link>

编程式路由导航

作用:不借助<router-link> 实现路由跳转,让路由跳转更加灵活
具体编码:

/ /$router的两个API
this.$router.push({
	name : 'xiangqing',
	params :{
		id :xxx,
		title :xXX
	}
})
this.$router.replace({
	name : "xiangqing',
	params :{
		id : xxX,
		title :xXX
	}
})
this.$router.forward()//前进
this.$router.back()//后退
this.$router.go()//可前进也可后退

在这里插入图片描述
修改 Banner

<template>
  <div class="col-xs-offset-2 col-xs-8">
    <div class="page-header">
      <h2>Vue Router Demo</h2>
      <button @click="back">后退</button>
      <button @click="forward">前进</button>
      <button @click="test">测试一下 go</button>
    </div>
  </div>
</template>

<script>
export default {
  name: "Banner",
  methods:{
    back(){
      this.$router.back()
    },
    forward(){
      this.$router.forward()
    },
    test(){
      this.$router.go(-3)
    }
  }
}
</script>

修改 Message

        
        <!--跳转路由并携带params参数,to的对象写法-->
        ......
        <button @click="pushShow(m)">push查看</button>
        <button @click="replaceShow(m)">replace查看</button>

<script>
export default {
  ......
  methods: {
    pushShow(m) {
      this.$router.push({
        name: 'xiangqing',
        query: {
          id: m.id,
          title: m.title
        }
      })
    },
    replaceShow(m) {
      this.$router.replace({
        name: 'xiangqing',
        query: {
          id: m.id,
          title: m.title
        }
      })
    }
  }
}
</script>

缓存路由组件

作用:让不展示的路由组件保持挂载,不被销毁
具体编码:

<keep-alive include="News">
	<router-view></router-view>
</keep-alive>

修改 News 组件,每个消息后展示输入框

<template>
  <ul>
    <li>news001 <input/></li>
    <li>news002 <input/></li>
    <li>news003 <input/></li>
  </ul>
</template>

当我们在后边输入框中输入文字,切换到别的链接,再切回来,会发现 input 内的文字就清空了,因为我们之前说过,当 News 切换走的时候,它已经被销毁了,我们可以在 beforeDestroy 中打印测试,这里不做演示
在这里插入图片描述
想要缓存这个页面,可以在 News 的最终展示区 Home 中增加标签router-view,然后使用 include 标识要缓存的组件名

<keep-alive include="News">
	<router-view></router-view>
</keep-alive>

再看效果
在这里插入图片描述
注意:
1、include后是组件名称
2、不写会缓存所有的
3、如果想缓存多个,可以写成数组

:include="['News','Message']"

两个新的生命钩子

作用:路由组件所独有的两个钩子,用于捕获路由组件的激活状态
activated路由组件被激活时触发
deactivated路由组件失活时触发

现在的需求是,我们希望在 News 组件周而复始的展示一个文字,之前我们写过就是使用 setInterval,然后在 beforeDestroy 中再销毁这个 setInterval,但是由于我们上一节中,已经把 News 设置了缓存,不会走 beforeDestroy 了,所以我们引入两个新的生命周期钩子

修改 News

<template>
  <ul>
    <li :style="{opacity}">欢迎学习Vue</li>
    <li>news001 <input/></li>
    <li>news002 <input/></li>
    <li>news003 <input/></li>
  </ul>
</template>

<script>
export default {
  name: "News",
  data() {
    return {
      opacity: 1
    }
  },
  activated() {
    this.timer = setInterval(() => {
      this.opacity -= 0.01
      if (this.opacity <= 0) this.opacity = 1
    },16)
  },
  deactivated() {
    clearInterval(this.timer);
  }
}
</script>

在这里插入图片描述


http://www.niftyadmin.cn/n/1816703.html

相关文章

嘿嘿,看看你属于哪个阶段的程序员? (转)

国外开发者博客中有一篇有趣的文章&#xff0c;将程序员按水平像软件版本号那样划分为不同的版本。相对于在招聘时分为初级&#xff0c;中级&#xff0c;高级程序员&#xff0c;直接表明 需要某种语言N版本的程序员或许更方便直接。根据作者的观点&#xff0c;可将WEB开发者大致…

[导入]GEF中导视图的使用

作者: liugang594 链接&#xff1a;http://liugang594.javaeye.com/blog/213545 发表时间: 2008年07月10日 声明&#xff1a;本文系JavaEye网站发布的原创博客文章&#xff0c;未经作者书面许可&#xff0c;严禁任何网站转载本文&#xff0c;否则必将追究法律责任&#xff01…

JavaScript调节透明度

动态改变照片的透明度 <img id"imgInfo" src"Images/Train.jpg" style"filter: alpha(opacity50)"/> <input id"Button1" type"button" value"透明度" οnclick"rdl_change(1)" /> …

HTML5上传图片预览

笔记一下&#xff01;&#xff01;&#xff01; <!DOCTYPE html> <html> <head> <title>HTML5上传图片预览</title> <meta http-equiv"Content-Type" content"text/html; charsetUTF-8"> <script src"http://…

Vue Element-UI使用

文章目录UI组件库介绍Element UI 使用UI组件库介绍 移动端常用UI组件库 VantCube UlMint UI PC端常用U组件库 Element UllView Ul Element UI 使用 全部引入 我们下面来演示一下 Element UI 的使用&#xff0c;它的 开发指南&#xff0c;根据步骤来做就可以了&#xff0c…

html5页面头部

<base href"/bulid/"/><meta charset"UTF-8"/><meta http-equiv"X-UA-Compatible" content"IEedge,chrome1"/> <!-- 尺寸的设置以及页面是否允许缩放 --> <meta name"viewport" content"wi…

在SQL2000、SQL2005查看阻塞进程的SQL脚本

--查阻塞 /****************************************************************************************************************************************************** 整理人&#xff1a;中国风(Roy)日期: ************************************************************…

Vue Vue3项目创建学习和npm

文章目录创建vue3项目使用vue cli创建使用vite创建分析目录结构安装开发者工具关于 npm 和 yarn创建vue3项目 使用vue cli创建 使用vue cli创建vue3项目官方文档 ##查看vue/cli版本&#xff0c;确保vue/cli版本在4.5.0以上 vue --version 或 vue -V ##安装或者升级你的vue/c…