移动端布局的一些设置(在viewport里设置使页面显示相同宽度,显示相同像素大小)...

viewport(视口)

  1. 具体数值(不设置时默认为980 ,部分安卓手机不支持设置成具体数值)
  2. width=device-width 和设备宽度保持一致
  3. user-scalable=no 是否允许用户缩放no/yes(iOS10不支持 近乎无解)
  4. initial-scale 初始缩放比例
  5. minimum-scale 最小缩放比例
  6. maximum-scale 最大缩放比例
页面宽度

页面宽度=device-width/scale

在页面中实现等比像素的JS代码:

<!--利用页面的像素比来进行页面的缩放 显示等比像素 但每个设备不是相同宽度-->
<script type="text/javascript">
(function(){
    var meta = document.createElement("meta"); 
    var scale = 1/window.devicePixelRatio;
    meta.name = "viewport";
    meta.content = "initial-scale="+scale+",minimum-scale="+scale+",maximum-scale="+scale;
    document.head.appendChild(meta);
})();   
</script>

在页面中实现相同宽度显示的JS代码:

<!--页面宽度适配 显示相同宽度 但每个设备所显示的像素大小不一样-->
<script type="text/javascript">
(function(){
    var meta = document.createElement("meta");
    var width = window.screen.width; 
    var targetWidth = 320;
    var scale = width/targetWidth;
    meta.name = "viewport";
    meta.content = "initial-scale="+scale+",minimum-scale="+scale+",maximum-scale="+scale;
    document.head.appendChild(meta);

})();   
</script>

window.devicePixelRatio 像素比

[不可改变,只能获取]

1px的内容放大N倍显示

[像素比为2 整个页面的内容就被放大两倍显示]

分辨率:屏幕图像的精密度,是指显示器所能显示的点数的多少

分辨率越高,像素越大,在相同宽度下,屏幕所能显示出来的东西越多,但是显示出来就越小。

移动端布局
  • 1em=当前元素的一个文字大小
  • rem(root em) 1rem=html的一个文字大小
  • [rem布局原理简单的来说就是把页面虚拟成一个网格,每行的格子的大小都是一致的,每行的格子也是固定的,我们在设置元素的尺寸的时候,不在固定使用PX,而是设置占了多少格格子,然后在根据页面宽度的不同,来修改每个格子的大小,从而使页面等比的缩放. ]
  • 通过js获取页面的宽度
<script type="text/javascript">
(function(){
    var html = document.documentElement;//获取到HTML
    var width = html.clientWidth// 获取html的宽度
    //html.style.fontSize html的字体大小
    html.style.fontSize = width/10 + "px"; 
    //console.log(width);   
    // 1rem = 1个格子的大小
})();
</script>
  • [ 使用rem时,注意页面接受的最小字体是12px,所以一般不会分超过25个格子,一般要适配最小的宽度是320 ]

转载于:https://www.cnblogs.com/Ivy-s/p/6850540.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值