前端炫酷展开效果

效果图

因为图片大小的问题换成了手机尺寸录制

.vue

bash 复制代码
<template>
  <div class="expand">
    <div class="expand-main" @wheel="handleWheel"
      :style="`--location:${location}%;--load-location:${location * -1}%;`">
      <!-- <video class="expand-media expand-left" autoplay loop muted playsinline src="/src/assets/瑶-大耳狗之梦-动态海报.mp4" />
      <video class="expand-media expand-right" autoplay loop muted playsinline src="/src/assets/瑶-大耳狗之梦-动态海报.mp4" /> -->
      <img class="expand-media expand-left" :src="media" />
      <img class="expand-media expand-right" :src="media" />
      <div class="expand-container">
        <div class="expand-content">
          <h1 class="expand-content-title">独行道</h1>
          <div v-html="text"></div>
        </div>
      </div>
    </div>
  </div>
</template>

<script setup>
import { ref } from 'vue'

const media = 'https://get.hnzmsz.com/gw/swiper-4.jpg'
const heightMax = 50
const location = ref(0)
const text = `<p>我清楚地知道人与人的路是不可复制的,我走在我自己的人生路上,哪怕路途的风雨再大,大到我举步维艰,哪怕荆棘丛生,刺得我伤痕遍布,我也仍旧痴痴笑笑体会此中滋味。</p>
<p>人的一生之精彩,在于自己追逐梦想的过程。不必苛求旁人的不失望或者喜欢。走自己的路,让旁人失望和不喜欢去吧。</p>
<p>人啊,走在自己的人生路上,就不要怕肮脏!踩着白骨和血肉,一步步走向辉煌!人啊,走在自己的人生路上,就不要怕悲伤!岂不闻 "天无绝人之路"!只要我想走,路就在脚下!</p>`
const handleWheel = (event) => {
  if (event.deltaY > 0) location.value = heightMax <= location.value ? heightMax : location.value + 10
  else location.value = 0 < location.value ? location.value - 10 : 0
};
</script>

<style scoped lang='scss'>
.expand{
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  position: relative;

  &-main{
    width: 100%;
    height: calc(100% + 1px);
    position: absolute;
    left:0;
    top: 0;
    overflow: hidden;
  }

  &-media{
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 1;
    object-fit: cover;
    transition: transform 0.2s ease; 
    will-change: transform;
  }

  &-left{
    clip-path: polygon(0 0, 0 100%, 100% 100%);
    top: -.5px;
    left: 0;
    transform: translate3d(var(--load-location), var(--location), 0);
  }

  &-right{
    clip-path: polygon(0 0, 100% 100%, 100% 0);
    top:0;
    right: 0;
    transform: translate3d(var(--location), var(--load-location), 0);
  }

  &-container{
    position: absolute;
    top: calc(100% - (var(--location) * 2));
    width: 100%;
    transition: top 0.2s ease;
  }

  &-content{
    max-width: 90%;
    width: max-content;
    margin: 0 auto;
    line-height: 30px;

    &-title{
      text-align: center;
    }
  }
}
</style>

遇到问题可以看我主页加我,很少看博客,对你有帮助别忘记点赞收藏。

相关推荐
万物得其道者成4 小时前
前端大整数精度丢失:一次踩坑后的实战解决方案(`json-bigint`)
前端·json
鹏北海4 小时前
移动端 H5 响应式字体适配方案完全指南
前端
姜太公钓鲸2335 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript
柳杉6 小时前
使用AI从零打造炫酷医疗数据可视化大屏,源码免费拿!
前端·javascript·数据可视化
凌云拓界6 小时前
前端开发的“平衡木”:在取舍之间找到最优解
前端·性能优化·架构·前端框架·代码规范·设计规范
zhengfei6117 小时前
【XSS payload 】一个经典的XSS payload
前端·xss
简单Janeee7 小时前
[Vue 3 从零到上线]-第四篇:组件化思维——把网页像积木一样拆解
javascript·vue.js·ecmascript
全栈老石8 小时前
手写一个无限画布 #1:坐标系的谎言
前端·canvas
XW01059998 小时前
4-11判断素数
前端·python·算法·素数
J2虾虾8 小时前
Spring Boot中使用@Scheduled做定时任务
java·前端·spring boot