这次给大家带来vue+jquery+lodash滑动时顶部悬浮固定功能实现详解,vue+jquery+lodash滑动时顶部悬浮固定功能实现的注意事项有哪些,下面就是实战案例,一起来看一下。
这个效果是一个项目中抽出来的一个demo效果。

前期准备:
1. 引入jQ
登录后复制
引入lodash.js
npm install lodash -D
登录后复制
fixTop.vue组件的
{{item.title}}
var throttle = require('lodash/throttle'); //从lodash中引入的throttle节流函数export default { name: 'navScroll2', data() { return { list: [ { title: 'AAAA', id: 1 }, { title: 'BBBB', id: 2 }, { title: 'CCCC', id: 3 }, { title: 'DDDD', id: 4 }, ], isFixed: false, //是否固定的 throttleScroll: null, //定义一个截流函数的变量 }; }, methods: { //滚动的函数 handleScroll() { let h = $(this.$refs.header).outerHeight(); //header的高度 let wh = $(window).scrollTop(); //滚动的距离的,为什么这里使用的jq,因为不用考虑的什么的兼容问题 let navH = $(this.$refs.nav).outerHeight(); //nav的高度 if (wh > h) { this.isFixed = true; } else { this.isFixed = false; } }, }, mounted() { //写在掉接口的里面的 this.$nextTick(() => { //这里使用监听的scroll的事件,为什么要使用的节流函数,如果不使用的,页面一直在滚动计算的,这样在 //使用手机时候,出现非常卡的,隔一段时间计算,大大降低了性能的消耗(具体的好处自己去查资料) window.addEventListener('scroll', this.throttleScroll, false); }); this.throttleScroll = throttle(this.handleScroll, 100); }, deactivated() { //离开页面需要remove这个监听器,不然还是卡到爆。 window.removeEventListener('scroll', this.throttleScroll); },};.fixtop2 { min-height: 100vh;}.header { height: 5rem; width: 100%; background-color: red;}.nav { display: flex; width: 100%; background-color: pink; &.isFixed { position: fixed; left: 0; top: 0; z-index: 9999; } .box { font-size: 0.3rem; padding: 0 0.3rem; height: 0.9rem; line-height: 0.9rem; color: #333333; flex: 1; }}.content { height: 20rem; li { width: 100%; height: 1rem; border-bottom: 1px solid #000; }}
登录后复制
相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!
推荐阅读:
Angular5路由传值方法总结
JS实现透明度渐变功能
以上就是vue+jquery+lodash滑动时顶部悬浮固定功能实现详解的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2761706.html