对点击卡片,hover设置border,出现抖动和div走位问题,解决方法

本文探讨了网页布局中出现的抖动问题,原因在于broder的变化导致元素重绘。提供了三种解决方案:透明边框、padding对冲以及使用outline来定义轮廓,后者不占空间,适用于鼠标hover和选中效果的一致性处理。
摘要由CSDN通过智能技术生成
抖动问题原因:设置的broder改变当前元素布局,会挤压空间,所以造成了抖动(因位置变化而出现的重绘现象),解决方法分为两种,一是改变元素本身大小,二是不更改布局,显示样式。

1.透明broder,对元素本身设置与目标broder宽度一致的透明边框

border:1px solid transparent;

2.padding,broder 对冲,设置和目标broder宽度一致的padding,之后当hover时重置

以上两种方法都没有办法解决,鼠标hover和选中元素的broder宽度不一的问题

3.outline,

outline 表示元素的轮廓,语法与border属性十分类似,分widthstylecolor。支持的关键字和属性与border属性一致,radio也适用

此属性与border存在一个重大的区别:outline不占据任何空间。

outline: 2px solid #3291fe;
outline-offset: -2px;

将偏移设置为目标宽度一样即可

在一个HTML `<div>`元素上同时设置鼠标悬停(`hover`)和点击(`click`)事件通常有两种方法: 1. **纯CSS实现(仅限于视觉效果)**: 对于简单的视觉反馈,你可以使用CSS伪类`:hover`和`:active`。例如: ```html <style> .myDiv { background-color: initial; transition: background-color 0.3s ease; } .myDiv:hover { background-color: lightblue; } .myDiv:active { background-color: darkblue; } </style> <div class="myDiv">Hover me and click</div> ``` 这里 `.myDiv:hover` 设置鼠标悬停时背景色变浅蓝,`.myDiv:active` 则设置鼠标按下时背景色变深蓝。注意这只会改变视觉效果,不是真正的交互。 2. **JavaScript实现(实际交互)**: 如果需要复杂的交互逻辑,比如延迟效果、计数等,可以利用JavaScript的`addEventListener`方法: ```javascript const myDiv = document.querySelector('.myDiv'); myDiv.addEventListener('mouseover', function() { // 鼠标悬停时执行的函数 this.style.backgroundColor = 'lightblue'; }); myDiv.addEventListener('mouseout', function() { // 鼠标离开时恢复原状 this.style.backgroundColor = ''; }); myDiv.addEventListener('mousedown', function() { // 鼠标按下时执行 this.style.backgroundColor = 'darkblue'; }); myDiv.addEventListener('mouseup', function() { // 鼠标抬起时恢复原状 this.style.backgroundColor = ''; }); ``` 上述代码中,`mouseover` 和 `mouseout` 用于处理悬停,`mousedown` 和 `mouseup` 分别处理点击开始和结束。 记得将`.myDiv`替换为你实际的元素ID或类名。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值