news 2026/4/23 9:58:44

Vue视差标题背景

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue视差标题背景

一、说明

这个我是为了放在博客的标题部分作为背景图,上下滚动的时候比较好看。

原理就是通过几张透明的png进行叠加,然后在上下滚动时,外层png移动的快,内层png移动得慢来实现视差效果。

先放一张示意图:

这里实际的距离X和Y在观察者看来是一样的,原因是距离观察者的距离Z不一样导致的。

视差示意图.png

再放一张视差标题背景的3d示意图:

实际示意图

二、Vue代码

这里为了代码高亮分三部分展示

html部分

<template>

<section>

<img :src="p0Src" id="p0" :style="{ transform: `translateY(${p0Top}px)`, zIndex: `100` }" alt="p0">

<img :src="p1Src" id="p1" :style="{ transform: `translateY(${p1Top}px)`, zIndex: `200` }" alt="p1">

<img :src="p2Src" id="p2" :style="{ transform: `translateY(${p2Top}px)`, zIndex: `300` }" alt="p2">

<img :src="p3Src" id="p3" :style="{ transform: `translateY(${p3Top}px)`, zIndex: `400` }" alt="p3">

<img :src="p4Src" id="p4" :style="{ transform: `translateY(${p4Top}px)`, zIndex: `500` }" alt="p4">

<img :src="p6Src" id="p6" :style="{ transform: `translateY(${p6Top}px)`, zIndex: `600` }" alt="p6">

<div id="banner_title"

class="container"

:style="{ marginRight: `0px`, marginTop: `${bannerTitleMarginTop}px`, width: `75%`}">

<h1>{{blogTitle}}</h1>

<p class="description">{{blogDescription}}</p>

</div>

</section>

</template>

js部分

<script>

const imgUrl = "https://xxxxxxxxxxxx/";

export default {

name: "Banner",

data() {

return {

p0Src: imgUrl + 'banner/ppp0.png',

p1Src: imgUrl + 'banner/pp1.png',

p2Src: imgUrl + 'banner/pp2.png',

p3Src: imgUrl + 'banner/pp3.png',

p4Src: imgUrl + 'banner/pp4.png',

p6Src: imgUrl + 'banner/pp6.png',

p0Top: 0,

p1Top: 0,

p2Top: 0,

p3Top: 0,

p4Top: 0,

p6Top: 0,

bannerTitleMarginTop: -100,

requestId: undefined, // 用于跟踪 requestAnimationFrame 的标识

};

},

props:{

blogTitle:{

type: String,

require: true

},

blogDescription:{

type: String,

require: true

},

},

mounted() {

this.addScrollListener();

},

beforeDestroy() {

this.removeScrollListener();

},

methods: {

addScrollListener() {

// 使用 passive 参数优化滚动性能

window.addEventListener('scroll', this.handleScroll, {passive: true});

},

removeScrollListener() {

window.removeEventListener('scroll', this.handleScroll);

},

handleScroll() {

const value = window.scrollY;

this.p0Top = value * 0.6;

this.p1Top = value * 0.36;

this.p2Top = value * 0.24;

this.p3Top = value * 0.16;

this.p4Top = value * 0.12;

this.p6Top = 0;

this.bannerTitleMarginTop = value * 1.1 - 100;

// 使用 requestAnimationFrame 更新样式

if (this.requestId === undefined) {

this.requestId = requestAnimationFrame(this.updateStyles);

}

},

updateStyles() {

// 清除请求动画帧标识

this.requestId = undefined;

}

}

}

</script>

style部分

<style scoped lang="scss">

section {

position: relative;

width: 100%;

height: 100vh;

padding: 0px;

display: flex;

justify-content: center;

align-items: center;

overflow: hidden;

img {

position: absolute;

top: 0;

left: 0;

width: 100%;

//height: 100%;

object-fit: cover;

pointer-events: none;

will-change: transform; // 提前告知浏览器哪些属性可能会发生变化

}

#p4,#p3,#p2,#p1,#p0 {

width: 100%;

height: 100%;

}

#p6 {

width: 100%;

height: 150%;

}

section::before {

content: '';

position: absolute;

bottom: 0;

width: 100%;

//height: 100px;

background: linear-gradient(to top, #1c0522, transparent);

//z-index: 1000;

}

}

@-webkit-keyframes bounce {

0%,10%,25%,40%,50% {

-webkit-transform: translateY(0) rotate(0deg);

transform: translateY(0) rotate(0deg)

}

20% {

-webkit-transform: translateY(-10px) rotate(0deg);

transform: translateY(-10px) rotate(0deg)

}

30% {

-webkit-transform: translateY(-5px) rotate(0deg);

transform: translateY(-5px) rotate(0deg)

}

}

@keyframes bounce {

0%,10%,25%,40%,50% {

-webkit-transform: translateY(0) rotate(0deg);

transform: translateY(0) rotate(0deg)

}

20% {

-webkit-transform: translateY(-10px) rotate(0deg);

transform: translateY(-10px) rotate(0deg)

}

30% {

-webkit-transform: translateY(-5px) rotate(0deg);

transform: translateY(-5px) rotate(0deg)

}

}

</style>

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/19 11:55:45

通达信好公式个股突破

{}VAR1:SMA(AMOUNT,10,1)/1000000; VAR2:REF(VAR1,1); VAR3:MA(REF(CLOSE,1),5); 收盘:VAR1*CLOSE/VAR3*1/10,COLOR009900,LINETHICK0,POINTDOT; 开盘:VAR1*OPEN/VAR3*1/10,POINTDOT,COLOR009900,LINETHICK0; 最高:VAR1*HIGH/VAR3*1/10,POINTDOT,COLOR009900,LINETHICK0; 最低:…

作者头像 李华
网站建设 2026/4/23 9:57:21

使用国产的librestreaming实现RTMP直播

Fmpeg开发实战&#xff1a;从零基础到短视频上线》一书的“10.2.2 FFmpeg向网络推流”介绍了轻量级流媒体服务器MediaMTX&#xff0c;通过该工具可以测试RTSP/RTMP等流媒体协议的推拉流。可是在此之前&#xff0c;得先有一个推流工具向MediaMTX推送视频流&#xff0c;这样末端的…

作者头像 李华
网站建设 2026/4/22 15:17:25

10 个AI论文工具,助本科生轻松写完毕业论文!

10 个AI论文工具&#xff0c;助本科生轻松写完毕业论文&#xff01; AI 工具如何让论文写作变得轻松高效 在当今信息爆炸的时代&#xff0c;高校学生尤其是本科生&#xff0c;面对毕业论文的撰写任务时常常感到无从下手。无论是选题、资料收集&#xff0c;还是撰写初稿、修改润…

作者头像 李华
网站建设 2026/4/18 7:15:57

qt5之实现一个视频播放器(亲测好用)

#ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <QMainWindow> #include <QMediaPlayer> #include <QVideoWidget> #include <QSlider> #include <QPushButton> <

作者头像 李华
网站建设 2026/4/21 11:00:21

【课程设计/毕业设计】基于springboot的在线考试系统的设计与实现考试评分管理,试卷管理【附源码、数据库、万字文档】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/13 6:30:22

【计算机毕业设计案例】基于springboot的云与糖蛋糕购物平台系统的设计与实现烘焙行业线上线下融合、个性化定制服务(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华