下面是关于“vue滚动固定顶部及修改样式的实例代码”的完整攻略:
下面是关于“vue滚动固定顶部及修改样式的实例代码”的完整攻略:
一、思路梳理
本文实例通过自定义指令来实现 vue 滚动固定顶部及修改样式的效果,核心步骤如下:
- 在指令 bind 钩子中获取当前元素的 offsetTop 和 scrollTop,记录在对象中。
- 在指令 inserted 钩子中添加滚动事件,判断当前元素是否到达顶部,如果到达顶部则设置该元素的 position 为 fixed,top 设置为 0。
- 在指令 unbind 钩子中移除该指令所绑定的事件。
二、实现代码
1. 自定义指令实现
// 指令名为vueFixed
Vue.directive('vueFixed', function (el, binding) {
const fixedCls = binding.value.fixedCls || 'fixed-top' // 固定后的样式名,支持传参自定义
let originTop = el.offsetTop // 元素距离页面顶部的高度
let originScrollTop = 0 // 滚动距离
window.addEventListener('scroll', fixed, true)
function fixed() {
originScrollTop = document.documentElement.scrollTop || document.body.scrollTop
if (originScrollTop >= originTop) {
el.style.position = 'fixed'
el.style.top = '0'
el.classList.add(fixedCls)
} else {
el.style.position = 'static'
el.style.top = null
el.classList.remove(fixedCls)
}
}
el.addEventListener('unbind', function () {
window.removeEventListener('scroll', fixed, true)
el.removeEventListener('unbind', arguments.callee)
})
})
2. 组件调用示例
<template>
<div>
<!-- 示例一:固定顶部并且设置样式 -->
<div v-vueFixed="{fixedCls:'fixed-top-style'}">我是需要固定的元素</div>
<!-- 示例二:固定顶部,无需修改默认样式,两种写法相同 -->
<div v-vueFixed>我是需要固定的元素</div>
</div>
</template>
<script>
export default {
name: 'Demo',
data() {
return {}
}
}
</script>
<style>
.fixed-top { /* 滚动固定时的样式 */ }
.fixed-top-style { /* 滚动固定时的样式 */ }
</style>
三、示例说明
示例一:
如上代码所示,通过给 vueFixed 指令传入 fixedCls 参数值 ‘fixed-top-style’,即可自定义固定后的样式。
也就是说,当该元素开始滚动固定时,新添加的 class 为 ‘fixed-top-style’,这时候可以通过 CSS 来修改滚动固定时元素的样式。
示例二:
如上代码所示,如果没有传入 fixedCls 参数值,则使用默认的样式。
此时,滚动固定时的样式不需要额外进行设置,而是默认的样式。
沃梦达教程
本文标题为:vue滚动固定顶部及修改样式的实例代码
猜你喜欢
- Ajax实现phpcms 点赞功能实例代码 2023-01-31
- Ajax+Servlet实现无刷新下拉联动效果 2023-02-14
- Js实现滚动变色的文字效果 2023-12-25
- Ajax发送和接收二进制字节流数据的方法 2022-12-28
- ie7中overflow:auto无效的解决方法 2024-02-20
- IE下元素空白区域(该元素在上img在下)与图片重叠无法触发鼠标事件 2024-01-03
- Vue前端换行问题 2023-10-08
- Ajax中文传值出现乱码的解决办法 2022-11-22
- vue form表单验证出现选择输入了值,但是还是提示未选择时的问题 2023-10-08
- Document.location.href和.replace的区别示例介绍 2024-01-16