当前位置:  开发笔记 > 前端 > 正文

CSS圈子的悬停区域增加

如何解决《CSS圈子的悬停区域增加》经验,为你挑选了1个好方法。

我的页面上的小元素的边框半径设置为50%,因此它们显示为小点:

CSS:

.star {
    width: 5px;
    height: 5px;
    background-color: rgb(236, 236, 236);
    position: absolute;
    border-radius: 50%;
    transform: scale(1);
    display: block;
    transition: 0.25s ease-in background-color, 0.25s ease-in opacity, 0.25s ease-out transform;
    cursor: pointer;
}

每一个都有一个悬停动作,会弹出一个弹出窗口。但是,现在存在一个问题,即悬停(至少在我测试过的浏览器中)是一个寻找像素的游戏。

是否有一个“技巧”在点上添加一个不可见的边框,使它们在不寻找像素的情况下更具选择性?

设置border2px solid transparent仅能使测试中的圆圈变大,而CSS outline不会产生:hover状态或mouseenter事件。



1> Paulie_D..:

使用伪元素增加“命中区域”

body {
  background: #000;
}

.star {
  width: 5px;
  height: 5px;
  background-color: rgb(236, 236, 236);
  position: absolute;
  left: 50%;
  top: 50%;
  border-radius: 50%;
  transform: scale(1);
  display: block;
  transition: 0.25s ease-in background-color, 0.25s ease-in opacity, 0.25s ease-out transform;
  cursor: pointer;
}

.star::before {
  content: '';
  position: absolute;
  border-radius: 50%;
  width: 500%;
  height: 500%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index:-1;
  border:1px solid green; /* for demo purposes */
  
}

.star:hover {
  background: #f00;
}
推荐阅读
落单鸟人
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有