移动端屏幕适配问题

简单适配样式

// 原理:1rem = viewWidth / 系数
//两种获取viewWidth的方法
document.documentElement.getBoundingClientRect().width
window.innerWidth
//封装
(function(){
	'use strict';
	setRemUnit();
	window.addEventListener('resize',setRemUnit)

	function setRemUnit(){
		var docEle = document.documentElement
		var ratio = 18.75 //设定系数
		var viewWidth = docEle.getBoundingClientRect().width 
					|| window.innerWidth;
		//设置html的字体大小
		docEle.style.fontSize = viewWidth / ratio + 'px'
	}
}

通用适配方案

//当你设置了一个1px的边框的时候,简单的适配方案就不起作用了,
//如何在使用px单位的情况下也能进行屏幕适配
//原理 dpr->scale = 1/dpr  缩放比例与设备像素比进行适配
(function(){
	'use strict';
	var docEl = document.documentElement,
	//获取meta标签
		viewportEl = document.querySelector('meta[name="viewport"]'),
	//获取像素比
		dpr = window.devicePixelRatio || 1,
		maxWidth = 540,
		minWidth = 320;
	//设置像素比
	dpr = dpr >= 3?3:(dpr>=2?2:1)
	docEl.setAttribute('data-dpr',dpr);
	//修改缩放比
	var scale = 1/dpr,
		content = 'width=device-width,initial-scale='+scale+',maximun-scale='+scale+',minimun-scale='+scale+',user-scalable=no';
	
	if(viewportEl){
		viewportEl.setAttribute('content',content);
	}else{
		viewportEl = document.createElement('meta')
		viewportEl.setAttribute('content',content);
		viewportEl.setAttribute('name','viewport');
		document.head.appendChild(viewportEl)
	}
	setRemUnit();
	window.addEventListener('resize',setRemUnit)

	function setRemUnit(){
		var ratio = 18.75 //设定系数
		var viewWidth = docEle.getBoundingClientRect().width 
					|| window.innerWidth;
		//设置html的字体大小
		if(maxWidth && (viewWidth / dpr > maxWidth)){
			viewWidth = maxWidth * dpr;//限制最大值
		}else if(minWidth && (viewWidth / dpr < minWidth)){
			viewWidth = minWidth * dpr;//限制最小值
		}
		docEle.style.fontSize = viewWidth / ratio + 'px'
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值