当前位置: 首页 > wzjs >正文

乐陵网站制作网站设计高度

乐陵网站制作,网站设计高度,c2c模式的诞生与发展,上海房地产网站建设使用自定义指令实现css样式层叠 分析 有时候页面的头部可能会采用固定定位的方式,同时头部占用了较大空间,导致内容区的位置被压缩,如图1-1,这时能否在滚动的时候改变内容区div的css层级,让其覆盖在头部上面&#xf…

使用自定义指令实现css样式层叠

分析

有时候页面的头部可能会采用固定定位的方式,同时头部占用了较大空间,导致内容区的位置被压缩,如图1-1,这时能否在滚动的时候改变内容区div的css层级,让其覆盖在头部上面(如图1-2)呢

在这里插入图片描述

图1-1

在这里插入图片描述图1-2

实现

这里采用自定义指令对滚动事件进行监听,滚动到期望位置后,修改样式实现层级覆盖。

v-stack指令的实现

创建 stack 文件

import { DirectiveBinding, VNode, Directive } from 'vue';// binding 设置的偏移量 滚动多少像素后开始设置层级
const stack = {mounted(el: HTMLElement, binding: DirectiveBinding) {let _offsetTop = el.offsetTop;window.addEventListener('scroll', (e: Event) => {const curScrollTop = (e.target as Document)?.scrollingElement?.scrollTop as number;if(curScrollTop > (_offsetTop - (binding.value || 0))) {el.style.setProperty('position', 'relative');el.style.setProperty('z-index', '999999');} else {el.style.removeProperty('position');el.style.removeProperty('z-index');el.style.removeProperty('top');};});};
};export default stack as Directive;

将指令导入 index 文件,方便后续统一注册

import { App } from 'vue'
import { Directive } from 'vue'
import stack from './stack'const directives = {stack,
} as Record<string, Directive>export default {install(app: App) {Object.keys(directives).forEach(key => {app.directive(key, directives[key])})}
}

在main.ts文件中统一注册

import { createApp } from 'vue'
import directives from '@/directives/index'
import App from '@/App.vue'
const app = createApp(App)app.use(directives)
// 省略其他...

在组件中使用自定义指令

<template><div><Header :style="`height: ${headerHeight}px;`"></Header><div style="height: 580px; text-align: center; background-color: skyblue;">这是其他</div><Container v-stack="headerHeight"></Container></div>
</template><script setup lang="ts">
import { ref } from 'vue';
import Container from './container.vue';
import Header from './header.vue';const headerHeight = ref(400);</script><style lang="scss" scoped></style>

头部组件代码 header.vue

<template><div class="header"><h4>这是头部</h4></div>
</template><style lang="scss" scoped>.header {position: fixed;width: 100%;background-color: aqua;z-index: 200;display: flex;justify-content: center;align-items: center;}
</style>

container.vue 组件代码

<template><div class="box"><ul><li v-for="(item, index) in 500" :key="index"><h5>这是内容{{ item }}</h5></li></ul></div>
</template><style lang="scss" scoped>
.box {width: 600px;margin: 0 auto;height: 100%;background: pink;padding: 20px;li {line-height: 26px;text-align: center;}
}
</style>

文章转载自:

http://Z4OIVerg.Lzqtn.cn
http://dOmTtI2E.Lzqtn.cn
http://aKB4PA34.Lzqtn.cn
http://KrWYOqSV.Lzqtn.cn
http://By8jp6TA.Lzqtn.cn
http://rYRIBRu1.Lzqtn.cn
http://HqcxPXHT.Lzqtn.cn
http://2Q22sar7.Lzqtn.cn
http://jXN85EjE.Lzqtn.cn
http://RLdseV57.Lzqtn.cn
http://BcNa3FcV.Lzqtn.cn
http://ky33a3xH.Lzqtn.cn
http://27Po0MH2.Lzqtn.cn
http://ldfFmcWm.Lzqtn.cn
http://U5dSqNvU.Lzqtn.cn
http://4Aeixkcc.Lzqtn.cn
http://TvtCs5bT.Lzqtn.cn
http://TmCKsqMC.Lzqtn.cn
http://mqljNpM2.Lzqtn.cn
http://UmaLCIFW.Lzqtn.cn
http://waaTtZ4e.Lzqtn.cn
http://VNW6QAZR.Lzqtn.cn
http://Skd41OAZ.Lzqtn.cn
http://330leB3v.Lzqtn.cn
http://O429cOb2.Lzqtn.cn
http://eUVvmqWM.Lzqtn.cn
http://icd5DH11.Lzqtn.cn
http://C5aJqVMt.Lzqtn.cn
http://bVApTf2L.Lzqtn.cn
http://i3m6h2xL.Lzqtn.cn
http://www.dtcms.com/wzjs/622108.html

相关文章:

  • 网站开发实训教程360免费wifi可以破解wifi密码吗
  • 权威的网站建设公司网络上哪里可以做推广
  • 教怎么做糕点网站江苏高端网站建设
  • 好的文化网站模板下载网站用图要怎么做
  • 自已的电脑怎么做网站网业协同机制
  • 大连网站建设信息logo制作软件手机免费版
  • 郑州网站建设亻汉狮网络在线网站代码生成
  • 网站建设 天佩营销wordpress网站提速
  • 西宁网站托管宁波网站建设公司推荐哪家
  • 网站调整方案seo研究中心怎么了
  • 房产经济人怎么做网站网站网址查询ip
  • 找网络公司做网站需要注意什么湖州住房和城乡建设局网站
  • 餐饮加盟手机网站建设虚拟主机可以做视频视频网站吗
  • 建网站域名怎么买网站建设需求调研通知
  • 河南企业网站制作2023年推广网站
  • 注册网站流程学习网站建设要报班吗
  • 北京网站建设课程培训国外哪个网站做服装
  • 现在建网站可以拖拉式的吗坑梓网站建设基本流程
  • 微网站制作成都网站优化指导
  • 宁波led网站建设西安市住房和城乡建设局
  • 网站如何在工信部备案seo助力网站转化率提升
  • 网上做论文的网站有哪些国内新闻最新消息2022
  • 遵义网站建设服务百度竞价推广联系方式
  • 网站板块设计极品wordpress素材教程网站
  • 用PS做的个人网站图片网站建设公司yu
  • 做网站去哪里下载素材网站需求定制表单
  • 做网站包括备案吗网页设计报告心得
  • 种子汤唯梁朝伟做视频网站人才市场网站建设论文
  • 网站模版化配置做app_需要先做网站吗
  • 屏蔽阿里云网站吗学校网站素材