如何在页面上实现一个圆形的可点击区域?

方法一:通过map加area

<img>标签中的 usemap 属性将图像定义为客户端图像映射。图像映射指的是带有可点击区域的图像。usemap 属性与 <map> 元素的 name 或 id 属性相关联。

这里通过 usemap 映射到 <map> 的circle形 <area>。

<area>标签类似<img>,是无法有子元素或其他子内容的。

  • shape表示点击热点区域的形状,支持矩形rect,圆形circle以及多边形poly。
  • 表示点击热点区域形状的坐标。圆形circle支持3个数值,前2个值为圆心坐标,第3个值为圆的半径大小。
  • href和<a>元素的href是一样的东西,直接跳转地址,或者锚点等。也同样支持target属性和rel属性。也就是说<area>可以看成是半个<a>元素。
<img src="images/lanlvseImg.png" usemap="#Map" />  
<map name="Map" id="Map">
	<area shape="circle" coords="100,100,50" href="http://www.baidu.com" target="_blank"/>
</map>

 

方法二:border-radius (css3)

设置div的border-radius:50%。

<div id="circle"></div>
#circle{
	background:red;
	width:100px;
	height:100px;
	border-radius:50%;
}

 

方法三:

JS实现,获取鼠标点击位置坐标,判断其到圆点的距离是否不大于圆的半径,来判断点击位置是否在圆内。

两点之间的距离计算公式:  |AB| = Math.abs(Math.sqrt(Math.pow(X2-X1), 2) + Math.pow(Y2-Y1, 2)))
Math.abs()求绝对值,Math.pow(底数,指数),Math.sqrt()求平方根

// 获取目标元素
var box = document.getElementById('box');
 
// 对目标元素target的圆形区域进行一个点击事件绑定
function bindClickOnCircleArea(target, callback) {
  target.onclick = function (e) {
    e = e || window.event;
 
    // target中心点的坐标
    var x1 = 100;
    var y1 = 100;
 
    // 事件源坐标
    var x2 = e.offsetX;
    var y2 = e.offsetY;
 
    // 校验是否在圆形点击区,在的话就执行callback回调
    // 计算事件触发点与target中心的位置
    var len = Math.abs(Math.sqrt(Math.pow(x2 - x1, 2) + Math.pow(y2 - y1, 2)));
    // 通过半径进行校验
    if (len <= 100) {
      callback();
    } else {
      alert('在外面');
    }
  }
}
 
// 执行
bindClickOnCircleArea(box, function () {
  alert('找到了');
});

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值