用vue写个顶部导航栏并且点击右边的标题会跑到中间
时间: 2024-05-01 22:16:37 浏览: 76
vue实现中部导航栏布局功能
以下是一个简单的示例代码,实现了一个顶部导航栏,点击右边的标题会跑到中间:
```
<template>
<div class="nav">
<div class="nav-left">
<span class="nav-title">左侧标题</span>
</div>
<div class="nav-center">
<span class="nav-title">{{ currentTitle }}</span>
</div>
<div class="nav-right">
<span class="nav-title" @click="scrollToCenter">右侧标题</span>
</div>
</div>
</template>
<script>
export default {
data() {
return {
currentTitle: '中间标题'
}
},
methods: {
scrollToCenter() {
// 获取中间标题的位置
const centerTitle = document.querySelector('.nav-center .nav-title')
const centerTitleRect = centerTitle.getBoundingClientRect()
const centerTitleOffset = centerTitleRect.left + centerTitleRect.width / 2
// 滚动到中间标题的位置
window.scrollTo({
left: centerTitleOffset - window.innerWidth / 2,
behavior: 'smooth'
})
}
}
}
</script>
<style scoped>
.nav {
display: flex;
align-items: center;
justify-content: space-between;
height: 50px;
background-color: #eee;
font-size: 18px;
font-weight: bold;
padding: 0 20px;
}
.nav-title {
cursor: pointer;
}
.nav-center {
flex-grow: 1;
text-align: center;
}
</style>
```
在这个示例中,顶部导航栏被划分为三个部分:左侧、中间和右侧。中间部分显示当前的标题,右侧部分的标题被点击时,页面会滚动到中间标题的位置。
为了实现滚动效果,我们使用了 `window.scrollTo()` 方法,将页面滚动到指定的位置。在这个方法中,我们需要传入一个对象,包含两个属性:`left`(水平滚动距离)和 `behavior`(滚动行为,可以是 "auto"、"smooth" 或 "instant")。
注意,在 `scrollTo()` 方法中计算滚动距离时,我们使用了 `window.innerWidth` 属性,这是窗口的内部宽度,也就是视口的宽度,不包括滚动条的宽度。我们可以用这个属性计算出中间标题的位置和窗口的滚动距离。
阅读全文