本文共 1256 字,大约阅读时间需要 4 分钟。
方法一:通过map加area
<img>标签中的 usemap 属性将图像定义为客户端图像映射。图像映射指的是带有可点击区域的图像。usemap 属性与 元素的 name 或 id 属性相关联。
这里通过 usemap 映射到 <map> 的circle形 <area>。
<area>标签
类似<img>
,是无法有子元素或其他子内容的。
<a>
元素的href是一样的东西,直接跳转地址,或者锚点等。也同样支持target属性和rel属性。也就是说<area>
可以看成是半个<a>
元素。
方法二:border-radius (css3)
设置div的border-radius:50%。
#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('找到了');});
转载地址:http://diuvi.baihongyu.com/