当前位置:首页 > 技术博客 > JavaScript > Bilibili头部景深对焦效果

Bilibili头部景深对焦效果

4年前 (2021-07-20)JavaScript1001

交互式鼠标悬停头图景深对焦效果

60f6949b0001dcde19150287.png


<head>      
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">    
		<title>B站头图景深对焦效果</title>    
<style>    
    body {    
    margin: 0;    
    }    
    header {    
    height: 160px;    
    position: relative;    
    overflow: hidden;    
    }    
    header > div {    
    position: absolute;    
    top: 0;    
    left: 0;    
    width: 100%;    
    height: 100%;    
    display: flex;    
    justify-content: center;    
    align-items: center;    
    --offset: 0px;    
    --blur: 2px;    
    }    
    header > div > img {    
    display: block;    
    width: 110%;    
    height: 100%;    
    object-fit: cover;    
    transform: translatex(var(--offset));    
    filter: blur(var(--blur));    
    }    
</style>    
</head>    
<body>    
<header>    
    <div><img src="https://pic3.58cdn.com.cn/nowater/webim/big/n_v2aa4e07773e834330a4879a85aaf52d20.png"></div>    
    <div><img src="https://pic1.58cdn.com.cn/nowater/webim/big/n_v21e2504548c9d46ad86eb8e1fb1343184.png"></div>    
    <div><img src="https://pic1.58cdn.com.cn/nowater/webim/big/n_v292447ee06af84d38a004ffcc74a26218.png"></div>    
    <div><img src="https://pic8.58cdn.com.cn/nowater/webim/big/n_v2c6b65cf6c5a54a8ca776a34045e2b349.png"></div>    
    <div><img src="https://pic2.58cdn.com.cn/nowater/webim/big/n_v2ea1dda358ed543df8628fcbf686f5230.png"></div>    
    <div><img src="https://pic1.58cdn.com.cn/nowater/webim/big/n_v23b40c7a5df42486084baa03b53e366be.png"></div>    
</header>        
	<h3 style="text-align: center">请在图片上左右移动鼠标查看效果</h3>    
<script>    
    const images = document.querySelectorAll('header > div > img')    
    document.querySelector('header').addEventListener('mousemove', (e) => {    
    let percentage = e.clientX / window.outerWidth    
    let offset = 10 * percentage    
    let blur = 20    
    for (let [index, image] of images.entries()) {    
    offset *= 1.3    
    let blurValue = (Math.pow((index / images.length - percentage), 2) * blur)    
    image.style.setProperty('--offset', `${offset}px`)    
    image.style.setProperty('--blur', `${blurValue}px`)    
    }    
    })    
</script>    
</body>


电脑端的朋友可以直接点击上面的【运行代码】按钮查看效果

版权声明:本文由 LzxBlog 发布,如需转载请注明出处。

本文链接:https://www.liuzhixi.cn/html/131.html

标签: JavaScriptHTML

相关文章

通俗的理解js中的&&和||

通俗的理解js中的&&和||

js中的&&和||本质是什么呢?进行布尔值的且和或的运算。当运算到某一个变量就得出最终结果之后,就返回哪个变量。在javascript中:以下内...

javascript 滚动插入元素动画特效

javascript 滚动插入元素动画特效

监听窗体滚动条,新的元素会以 左移、右移、淡出、淡入 等各种方式插入到文档流中<head>     <...

前端用法:JavaScript 获取当前GPS地理位置的方法,保姆级代码!

前端用法:JavaScript 获取当前GPS地理位置的方法,保姆级代码!

在网上搜到很多,99%不能用,自己动手将整理记录一下吧,以便后续再使用!<head>     <ti...

关于bootstrap.min.js.map报错404的问题

关于bootstrap.min.js.map报错404的问题

相信很多用过BootStrap框架的伙伴都遇到过bootstrap.min.js.map 404的错误,明明自己并没有去调用这个文件为什么会报这个错误呢?小沫就...

大气磅礴的滑块网页背景

大气磅礴的滑块网页背景

<html>     <head>     <...

JavaScript时间日期的基操

JavaScript时间日期的基操

javascript 时间的基本操作,记录一下方便日后Ctrl C / Ctrl V获取当前月份的总天数:由于JavaScript中day的范围为1~31中的值...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。