html中map area 热区自适应的原生js实现方案

Posted 前端一点红

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了html中map area 热区自适应的原生js实现方案相关的知识,希望对你有一定的参考价值。

在做自适应网页的时候,如果在图片中使用了热区map。图片可以通过样式实现:图片大小随页面变化,但是MAP中每个area的坐标并不能通过css直接实现自适应。这篇文章就介绍通过原生js来实现:MAP中每个area的坐标也随页面等比例的变化效果。

 

map area 热区自适应的实现代码

html:

<style>
img{
	display:block;max-width:1920;width: 100%;border: 0;
}	
</style>
<img src="src/1.jpg" usemap="#planetmap"/>
<map name="planetmap" id="planetmap">
	<area shape="rect" coords="0,0,110,200" href="#"/>
	<area shape="rect" coords="50,50,200,200" href="#"/>
</map>

  

 

js:

<script>
var initwidth=null,//初始图片宽度
	area=document.getElementsByTagName(‘area‘),
	initarea=null;//初始数据保存
	
function init(){//初始化
	initwidth=1920;
	initarea=new Array(area.length-1);
	for(var i=0;i<area.length;i++){
		initarea[i]=area[i].getAttribute("coords");
	}
}

function setCoords(){//根据分辨率自适应热区坐标
    var width=document.body.offsetWidth,
    	percent=width/initwidth;
    for(var i=0;i<area.length;i++){
    	var coords=initarea[i],
    		arr=coords.split(",");
        for(var j=0;j<arr.length;j++){
            arr[j] *= percent;    
        }
        area[i].setAttribute("coords",arr.join(","));
    }
} 
//使用
init();
window.onresize = function () {  
    setCoords();
}  
</script>

资源网站大全 https://55wd.com 设计导航https://www.wode007.com/favorites/sjdh

大家在实际开发,请参照代码根据直接的需求改进。如果html页面中存在多个图片需要area,请自行封装实现!

 

以上是关于html中map area 热区自适应的原生js实现方案的主要内容,如果未能解决你的问题,请参考以下文章

原生js移动端字体自适应方案

70.JS---利用原生js做手机端网页自适应解决方案rem布局

js中网页前进和后退的代码

手机端页面自适应解决方案

手机端页面自适应解决方案

妙味云课堂之css:其它知识点汇总