JavaScript面试题:实现圆形可点击区域

文章介绍了三种创建圆形可点击区域的方法:一是使用CSS3的border-radius属性创建圆形元素并监听点击事件;二是利用HTML的map和area标签定义图像的热点区域;三是通过JavaScript进行坐标判断来实现点击事件在圆形区域内生效。
摘要由CSDN通过智能技术生成

方式一:border-radius(css3)样式实现

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin:0;
            padding:0
        }
        #circle {
            height: 100px;
            width: 100px;
            border-radius: 50%;
            background-color: red;
        }
    </style>
</head>

<body>
    <div id="circle" >

    </div>
    <script>
        var circle = document.getElementById("circle")
        circle.onclick = function(e){
            console.log("点击了");
            var x = e.pageX
            var y = e.pageY
            console.log(x,y);
        }
    </script>
</body>

</html>

方式二:map标签+area标签

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    </style>
</head>

<body>
    <img src="img/view.jpg" width="200" border="0" usemap="#Map" />
    <map name="Map" id="Map">
      <area shape="circle" coords="100,100,100" href="http://www.baidu.com" target="_blank" />
    </map>
</body>

</html>

效果就是点击图片中间定义的圆形区域后会跳转页面

map标签中属性介绍

  • shape
    shape表示点击热点区域的形状,支持矩形rect,圆形circle以及多边形poly。

  • coords
    coords表示点击热点区域形状的坐标。坐标点0,0表示图片的左上角。其中矩形rect支持4个数值,2个坐标,分别是矩形左上角坐标和矩形右下角坐标。例如,coords="20,20,80,80"生成的就是一个左上角坐标20,20宽高都是60px的矩形区域。圆形circle支持3个数值,前2个值为圆心坐标,第3个值为圆的半径大小。多边形poly就更简单了,每两个数值组合表示一个坐标点,依次连线形成的区域就是最终的热点区域。

  • href
    href和< a>元素的href是一样的东西,直接跳转地址,或者锚点等。也同样支持target属性和rel属性。也就是说< area>可以看成是半个< a>元素。

  • alt
    alt同< img>元素的alt,表示热点区域图片的描述信息。
    如果< area>要想和图片热点关联,祖先元素< map>是不可缺少的,但是不一定非得直接父子关系。< map>和< area>之间再嵌套个< div>什么的功能也是正常的。

方式三:js进行区域判断,进而形成可点区域

// 获取目标元素
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('圆形区域里面');
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值