Vue3哈希模式实现锚点导航方式
vue3利用哈希模式实现锚点导航
在Vue.js应用中,实现哈希模式的锚点导航是一项常见而有用的功能。
通过哈希模式,我们可以在页面间快速跳转,而无需重新加载整个页面,这对于提升用户体验尤为重要。
本文将介绍如何在Vue应用中利用哈希模式实现锚点导航,并且结合CSDN的使用进行详细说明。
准备工作
首先,确保你的Vue项目已经初始化,并且已经安装了Vue Router。
如果还没有安装Vue Router,你可以通过以下命令进行安装:
设置路由
在Vue Router中,我们需要将路由模式设置为哈希模式。
在创建Vue Router实例时,可以通过设置mode: 'hash'来启用哈希模式。
// router/index.js
import { createRouter, createWebHashHistory, RouteRecordRaw } from "vue-router";
export const routes: Array<RouteRecordRaw> = [
...
]
const router = createRouter({
history: createWebHashHistory(),
routes,
});
export default router;
组件使用
<script setup lang="ts">
const scrollToAnchor = (data: string) => {
// 从完整路径中解析出真正的锚点部分
const hash = data; // 注意:根据你的URL结构调整索引
if (hash) {
const element = document.getElementById(hash);
if (element) {
element.scrollIntoView({ behavior: "smooth" });
}
}
};
const onLiclick = (event: any) => {
scrollToAnchor(event.target.dataset.hash);
};
</script><template>
<div>
<nav>
<ul @click="onLiclick">
<li data-hash="my-box">首页</li>
<li data-hash="chanpin-box">产品介绍</li>
<li data-hash="news-box">实时新闻</li>
<li data-hash="about-box">关于我们</li>
<li data-hash="lianxi-box">联系我们</li>
</ul>
</nav>
<div class="pages">
<div id="my-box">
<h1>我的</h1>
</div>
<div id="chanpin-box">
<h1>产品介绍</h1>
</div>
<div id="news-box">
<h1>实时新闻</h1>
</div>
<div id="about-box">
<h1>关于我们</h1>
</div>
<div id="lianxi-box">
<h1>联系我们</h1>
</div>
</div>
</div>
</template><style scoped lang="scss">
ul {
display: flex;
position: fixed;
z-index: 999;
margin: auto;
left: 50%;
li {
cursor: pointer;
padding: 10px 20px;
}
}
h1 {
margin: 0px;
}
</style>
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
vue3使用threejs实现3D卡片水平旋转效果的示例代码
这篇文章主要介绍了在vue3中使用threejs实现3D卡片水平旋转效果,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下2024-04-04
Vue踩坑之Vue Watch方法不能监听到数组或对象值的改变详解
Vue 提供了一种更通用的方式来观察和响应 Vue 实例上的数据变动:侦听属性,下面这篇文章主要给大家介绍了关于Vue踩坑之Vue Watch方法不能监听到数组或对象值的改变的相关资料,需要的朋友可以参考下2022-04-04
Vue 动态组件components和v-once指令的实现
这篇文章主要介绍了Vue 动态组件components和v-once指令的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-08-08
vue中调接口的方式详解this.$api、直接调用、axios
这篇文章主要介绍了vue中调接口的方式:this.$api、直接调用、axios,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-11-11
vue和react等项目中更简单的实现展开收起更多等效果示例
这篇文章主要介绍了vue和react等项目中更简单的实现展开收起更多等效果示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-02-02


最新评论