使用js换算mm,cm,px

10 篇文章 0 订阅

问题开始

今天工作上遇到了一个问题,用户需要在网页上的A4纸上盖章,且章子必须尺寸与纸张尺寸需要一致。用户自己是可以设置印章尺寸的,但是我将印章的尺寸需要转化成px来定位,那么问题来了,如何将毫米mm转为像素呢?我在网上找了一堆代码,并没啥实用价值,一些参数都是固定设备尺寸的约值,很多博客都是一大堆原理,一堆计算,且显示器的尺寸和分辨率五花八门,我们怎么才能算的准?我看了十几篇博客,都是在讲dpi,没一个能快速实现我想要的效果。

下面上代码,我们把转换值的过程交给浏览器完成,我们不需要去知道设备的尺寸和比例,岂不美哉?

代码

	// 获取每毫米的像素值
	function getOneMmsPx (){
		// 创建一个1mm宽的元素插入到页面,然后坐等出结果
		let div = document.createElement("div");
		div.id = "mm";
		div.style.width = "1mm";
		document.querySelector("body").appendChild(div);
		// 原生方法获取浏览器对元素的计算值
		let mm1 = document.getElementById("mm").getBoundingClientRect();
		console.log(mm1);
		return mm1.width;
	} 

图片
在这里插入图片描述

结语

假如你想获取别的单位和像素的换算,就用别的单位代替1mm就是的,将换算的过程交给浏览器去实现,这是一种解决思路,或许有别的方法,但是我相信这个是最便捷且最容易理解的。

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值