css:倒影倾斜效果

这是需要实现的效果,平时用的比较多的是添加阴影,是box-shadow,而添加倒影是box-reflect,需要注意的是box-reflect需要添加浏览器前缀,比如我用的谷歌浏览器,要加-webkit-才能生效。

css 复制代码
-webkit-box-reflect: below 3px linear-gradient(to bottom,
				transparent 90%,
				rgba(0, 0, 0, 0.3) 100%
			);
		/* 参数说明:
		     below - 倒影方向(下方)
		     0px   - 倒影与图片的间距
		     linear-gradient - 渐变遮罩(使倒影渐隐)
		  */

倒影需要注意的是渐变设置,由于倒影是倒过来的,所以上面是bottom,下面是top,如下图所示。0-90%都是透明色,然后90%-100%从透明色渐变成半透明色,遮罩在图片倒影上。

如果不设置渐变,那么就是整个倒影全部显示出来的。

3d倾斜样式,要现在图片容器上增加透视效果,perspective: 1000px;

然后图片设置transform: translate3d(0px, 0px, -10px) rotateX(0deg) rotateY(30deg) scale(1);

再添加一点动效,比如鼠标hover的时候,图片回正,transform: none;

想要动效更流畅,又加了transition: transform 1s linear;

但是加了transition后悲催的发现,图片旋转回正后会有视觉残留,360浏览器无此问题而谷歌浏览器有,查了一圈资料,加浏览器前缀-webkit-,加

复制代码
backface-visibility: hidden;
backface-visibility: hidden;
transform-style: preserve-3d;
will-change: transform;

一概不管用。

完整代码如下,如果有网友解决了谷歌浏览器视觉残留问题,麻烦给我留个言,非常感谢了。

javascript 复制代码
<template>
	<!-- 倒影案例 -->
	<div class="container">
		<img src="../assets/1.png" />
		<img src="../assets/2.png" />
	</div>
</template>

<script>
</script>

<style scoped>
	.container {
		padding: 50px;
		display: flex;
		justify-content: space-around;		/* 图片左右分布 */
		perspective: 1000px; 		/* 增加3D透视效果 */
	}
	.container img {
		width: 40%;
		height: 300px;
		border-radius: 10px;
		-webkit-box-reflect: below 3px linear-gradient(to bottom,
				transparent 90%,
				rgba(0, 0, 0, 0.3) 100%
			);
		/* 参数说明:
		     below - 倒影方向(下方)
		     0px   - 倒影与图片的间距
		     linear-gradient - 渐变遮罩(使倒影渐隐)
		  */
		transition: transform 1s linear; /*加transition在谷歌浏览器上会有视觉残留问题*/
	}
	
	/* 图片容器里要设置perspective,子元素的translate3d才能生效*/
	/* 第一张图片往右倾斜 */
	.container img:nth-child(1) {
		transform: translate3d(0px, 0px, -10px) rotateX(0deg) rotateY(30deg) scale(1);
	}
	
	/* 第二张图片往左倾斜 */
	.container img:nth-child(2) {
		transform: translate3d(0px, 0px, -10px) rotateX(0deg) rotateY(-30deg) scale(1);
	}
	.container img:nth-child(1):hover {
		transform: none;
	}
	.container img:nth-child(2):hover {
		transform: none;
	}
	
</style>
相关推荐
shmily麻瓜小菜鸡20 分钟前
在 Angular 中, `if...else if...else`
前端·javascript·angular.js
bloglin999991 小时前
npm和nvm和nrm有什么区别
前端·npm·node.js
2501_910227541 小时前
web3 前端常见错误类型以及错误捕获处理
前端·web3
哎哟喂_!2 小时前
Node.js 同步加载问题详解:原理、危害与优化策略
前端·chrome·node.js
__BMGT()2 小时前
C++ QT图片查看器
前端·c++·qt
未来之窗软件服务2 小时前
solidwors插件 开发————仙盟创梦IDE
前端·javascript·数据库·ide·仙盟创梦ide
Varpb3 小时前
【vue】【环境配置】项目无法npm run serve,显示node版本过低
前端·vue.js·npm
读心悦3 小时前
CSS 溢出内容处理、可见性控制与盒类型设置深度解析
前端·css
Minyy113 小时前
Vue3指令(二)--v-text、v-html数据渲染,计算属性
前端·javascript·vue.js·前端框架·vue·html
个人开发-胡涂涂3 小时前
ECMAScript标准:JavaScript的核心
前端·javascript·ecmascript