vue.js滑动到顶便锁定位置

html 复制代码
<template>
  <div>
   <div class="nav"></div>
  <div class="searchBar" id="searchBar">
   <ul :class="searchBarFixed == true ? 'isFixed' :''"> 
    <li>区域<i class="iconfont icon-jiantouxia"></i></li>
    <li>价格<i class="iconfont icon-jiantouxia"></i></li>
    <li>房型<i class="iconfont icon-jiantouxia"></i></li>
    <li>更多<i class="iconfont icon-jiantouxia"></i></li>
   </ul>
  </div>
  <div class="content">
  </div>
  </div>
  </template>
  <script>
   export default {
    components:{
    },
  mounted () {
   window.addEventListener('scroll', this.handleScroll)
  },
      data(){
       return {
        searchBarFixed:false
      } 
   },
    methods:{
  handleScroll () {
   var scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop
   var offsetTop = document.querySelector('#searchBar').offsetTop
   if (scrollTop > offsetTop) {
    this.searchBarFixed = true
   } else {
    this.searchBarFixed = false
   }
  },
   }
   }
  </script>
  <style lang="less" scope>
  .nav{
   height: 250px;
  }
  .content{
   height: 1900px;
  }
  .searchBar{
   .isFixed{
    position:fixed;
    background-color:#Fff;
    top:0;
    z-index:999;
   }
   ul {
    width:100%;
    height: 40px;
    line-height: 40px;
    display: flex;
    li {
     list-style: none;
     font-size: 0.8rem;
     text-align: center;
     flex: 1;
     i {
      font-size: 0.9rem;
      padding-left: 5px;
      color: #ccc;
     }
    }
    border-bottom: 1px solid #ddd;
   }
  }
  </style>

修改为css样式

html 复制代码
<template>
  <div>
    <div class="nav"></div>
    <div class="searchBar" ref="searchBar" :class="{ isFixed: searchBarFixed }">
      <ul>
        <li>区域<i class="iconfont icon-jiantouxia"></i></li>
        <li>价格<i class="iconfont icon-jiantouxia"></i></li>
        <li>房型<i class="iconfont icon-jiantouxia"></i></li>
        <li>更多<i class="iconfont icon-jiantouxia"></i></li>
      </ul>
    </div>
    <div class="content"></div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      searchBarFixed: false,
    };
  },
  mounted() {
    this.$nextTick(() => {
      window.addEventListener('scroll', this.handleScroll);
      this.handleScroll();  // 初次加载时执行一次
    });
  },
  beforeDestroy() {
    window.removeEventListener('scroll', this.handleScroll);
  },
  methods: {
    handleScroll() {
      this.$nextTick(() => {
        const searchBar = this.$refs.searchBar;
        if (!searchBar) {
          console.warn('searchBar ref is undefined');
          return;
        }

        const scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;
        const offsetTop = searchBar.offsetTop;

        if (scrollTop > offsetTop) {
          this.searchBarFixed = true;
        } else {
          this.searchBarFixed = false;
        }
      });
    },
  },
};
</script>

<style>
/* General Styles */
.nav {
  height: 250px;
}

.content {
  height: 1900px;
}

/* Search Bar Styles */
.searchBar {
  position: relative;
  z-index: 10;
  transition: top 0.3s;
  width: 100%; /* 让 searchBar 宽度和父容器相同 */
  max-width: 1200px; /* 设置一个最大宽度 */
  margin: 0 auto; /* 让其水平居中 */
}

.searchBar.isFixed {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%); /* 使其保持居中 */
  width: 100%; /* 宽度保持不变 */
  max-width: 1200px; /* 固定宽度 */
  background-color: #fff;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  z-index: 9999;
}

.searchBar ul {
  width: 100%;
  height: 40px;
  line-height: 40px;
  display: flex;
  justify-content: space-around;
  background-color: #fff;
  border-bottom: 1px solid #ddd;
}

.searchBar ul li {
  list-style: none;
  font-size: 0.8rem;
  text-align: center;
  flex: 1;
}

.searchBar ul li i {
  font-size: 0.9rem;
  padding-left: 5px;
  color: #ccc;
}
</style>

当然也可以直接利用css 直接完成此功能 不影响后续操作前提你有相对参考

html 复制代码
<div class = "stickyRight">
<div class="right-nav">
</div>
</div>

css布局

css 复制代码
.stickyRight{
position:sticky;
top:0
}

上诉代码含义为当距离顶端0px right-nav在窗口位置固定不动。

相关推荐
牧艺24 分钟前
cos-design v3.0:从 15 个 Demo 到 49 个组件的视觉特效库
前端·视觉设计
lichenyang45326 分钟前
ASCF 架构升级总览:WebRuntimePage 为什么要变薄
前端
道友可好26 分钟前
从今天开始:你的第一个 Harness Engineering 实践
前端·人工智能·后端
Linsk28 分钟前
组件 = 模板 + 业务逻辑
java·前端·vue.js
二月龙1 小时前
移动端 H5 页面开发:响应式适配 + 低版本兼容实战指南
前端
小强19881 小时前
HTML5 新表单全解:日期、手机号、颜色选择器
前端
妙码生花1 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(二):目录结构、初始化 GIT、设计并开发配置系统
前端·后端·go
鱼人1 小时前
HTML5 本地存储终极指南
前端
超绝大帅哥1 小时前
React的Fiber是什么? Vue为什么不需要Fiber ?
前端
yingyima1 小时前
正则表达式分组与捕获:凌晨3点服务器报警的解决方案
前端