vue怎样实现点击跳转页面,方法是什么
Admin 2022-08-10 群英技术资讯 469 次浏览
页面跳转,我们一般都通过路由跳转实现,通常情况下可直接使用router-link标签实现页面跳转,但是如果我们想通过点击别的标签实现页面跳转,怎么办呢?这个时候我们就要用到this.$router.push()方法,下面来给大家简单介绍一下使用!
1.首先我们要定义一个点击事件
2.在定义事件中调用this.$router.push()方法
<template> <button @click = "handle">点击跳转</button> </template> <script> export default{ methods:{ handle (){ // 路径/home对应我在router目录下index.js中定义的path属性值 this.$router.push('/home'); } } } </script>
目标跳转页面路由在router目录下index.js定义如下:
export default new Router({ routes: [ { path: '/home', name:'Home', component: Home, }, ] })
参数为字符串,即路径名称
// 路径/home对应router目录下index.js中定义的path属性值 this.$router.push('/home');
参数为对象
// 对应router目录下index.js中定义的path this.$router.push({path:'/home'});
参数为路由命名
// 对应router目录下index.js中定义的name this.$router.push({name:'Home'});
带传递参数
// params里面放置的是我们要传递过去的参数 this.$router.push({name:'Home',params:{user:'david'}});
带查询参数
// 带查询参数,传递过去的内容会自动拼接变成/home?user=david this.$router.push({path:'/home',query:{user:'david'}});
当我们使用params进行传参时,只需在接收参数的地方使用this.$route.params进行接收即可
eg:
//传参 this.$router.push({name:'Home',params:{user:'david'}}); // 在name为Home的组件中接收参数 const id=this.$route.params.id; console.log(this.$route.params);//打印结果为{user:'david'}
当我们使用query传参时,只需在接收参数的地方使用this.$route.query进行接收即可,用法同上
!!!这里有一个小细节:$符号后面跟的是route不是router,跳转的时候 $后面跟的是router!!!
例如,从网站的首页点击跳转到指定页面的底部。
首页 home
<div @click="toPath('/targetPage#target')"> <p>点击跳转</p> </div>
methods:{ //点击跳转方法 toPath(path) { this.$router.push({path: path}) } }
跳转到的页面 targetPage
<div class="location" id="target"> <p>指定位置</p> </div>
//在mounted里 mounted() { var hash = window.location.hash; var index = hash.lastIndexOf("#"); if (index != -1) { var id = hash.substring(index + 1, hash.length + 1); var div = document.getElementById(id); if (div) { setTimeout(function () { console.log($(div).offset().top); $('html, body').animate({scrollTop: $(div).offset().top - 43}, 500) }, 500); } } }
亲测有效 :D
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
一、设置静态文件目录语法如下:app.use(express.static(_dirname+'/public'));//设置静态文件目录注:将静态文件目录设置为项目根目录+‘/public’,可以这样写app.use(express.stat
find选择器在jquery中用于 选择指定元素下面的所有子元素 ,返回的是标签数组object对象,下面是find选择器使用示例。 html部分代码 divid=testullilistitem1/lililistitem2/lililistitem3/li/ul/divullidivtest外面的元素/li/ul jquery find选择器使用格式
这篇文章主要为大家详细介绍了JS实现网页导航条特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
Vue众所周知是一个轻量级的框架,源码仅仅为72.9KB,但是也有它自己的缺点,就是首屏加载会比较慢,这篇文章主要给大家介绍了关于Vue项目首屏性能优化组件的相关资料,需要的朋友可以参考下
这篇文章主要介绍了js 标签语法使用,在 JavaScript 中提供了标签语句,用于标记指定的代码块,便于跳转到指定的位置。本文来记录一下标签语句的使用方法,需要的朋友可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008