我的理解请老师看一下

我的理解请老师看一下

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style>
			.father{
				width: 400px;
				height: 400px;
				margin: 0 auto;
			}
			.father:hover{
				will-change: width;
			}
			.child{
				width: 100px;
				height: 100px;
				margin: o auto;
				background-color: yellow;
				transition: 2s ease-in-out;
			}
			.child:hover{
				width: 300px;
			}
		</style>
	</head>
	<body>
		<div class="father">
			<div class="child"></div>
		</div>
	</body>
</html>

在这里给father的hover伪元素添加will-change通知浏览器要执行GPU加速,因为在father和child之间有一段距离,所以能留给浏览器准备加速的时间,而在child子元素需要加速时,GPU已经准备好优化动画了,当移出father时,will-change属性也会消失,把内存还给了浏览器。

正在回答

登陆购买课程后可参与讨论,去登陆

2回答

@ZZZZZzn同学你好,因为hover中的样式只有在鼠标移入时生效, 放在hover中是为了鼠标移出时,就移除这个样式。

祝学习愉快 ~

好帮手慕夭夭 2020-03-27 10:04:44

同学你好,可以这样理解哦。另外,事件开发中不常用,简单的练习一下即可。

继续加油,祝学习愉快 !

  • ZZZZZzn #1
    这里可不可以把will-change直接放在.father{ width: 400px; height: 400px; margin: 0 auto; } 里面呢?为什么还要hover
    2020-04-06 15:42:50
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师