【JS自适应】自适应 屏幕 更改页面 html根文字大小 JS 代码

自适应 屏幕 更改页面 html根文字大小 JS 代码

  • 可直接 运行
  • 注意事项
    • 此处 设计图 以 750 为准(可根据设计稿-改大小)
    • 当设计稿 750 时刚好 1rem = 100px
    • 100 * (clientWidth / 750)
      • 100 ? 是份数? 什么份数?
(function(doc, win) {
		    var docEl = doc.documentElement,
		        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
		        recalc = function() {
		            var clientWidth = docEl.clientWidth;
		            if(!clientWidth) return;
		            if(clientWidth >= 750) {
		                docEl.style.fontSize = '100px';
		            } else {
		                docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';
		            }
		        };
		 
		    if(!doc.addEventListener) return;
		    
		    win.addEventListener(resizeEvt, recalc, false);
		    doc.addEventListener('DOMContentLoaded', recalc, false);
		})(document, window)

拓展

  • 结合flex 布局使用 可达到更加 层次连续渐进的优美效果!!!!

测试文件

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<title>test</title>
	<style>
		main{
			width: 2rem;
			height: 2rem;
			background-color: tomato;
		}
		p{
			font-size: 0.2rem;
		}
	</style>
</head>
<body>
	<main>
		<p>hello world!</p>
	</main>
	<script>
		(function(doc, win) {
		    var docEl = doc.documentElement,
		        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
		        recalc = function() {
		            var clientWidth = docEl.clientWidth;
		            if(!clientWidth) return;
		            if(clientWidth >= 750) {
		                docEl.style.fontSize = '100px';
		            } else {
		                docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';
		            }
		        };
		 
		    if(!doc.addEventListener) return;

		    win.addEventListener(resizeEvt, recalc, false);
		    doc.addEventListener('DOMContentLoaded', recalc, false);
		})(document, window)
	</script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值