移动端布局的一些设置(在viewport里设置使页面显示相同宽度,显示相同像素大小)
viewport(视口)
- 具体数值(不设置时默认为980 ,部分安卓手机不支持设置成具体数值)
 - width=device-width 和设备宽度保持一致
 - user-scalable=no 是否允许用户缩放no/yes(iOS10不支持 近乎无解)
 - initial-scale 初始缩放比例
 - minimum-scale 最小缩放比例
 - 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 ]
 
移动端布局的一些设置(在viewport里设置使页面显示相同宽度,显示相同像素大小)的更多相关文章
- 在Linux系统中如何设置APACHE服务器里的后台页面只允许某个IP地址访问
		
补充资料 本网络中使用LINUX服务器,web服务器是由APACHE搭建,IP地址为192.168.1.5,后台页面为/admin/login.jsp . 如何设置后台页面LOGIN.JSP只允许19 ...
 - 移动端布局基础viewport
		
划重点 手机屏幕相对着桌面浏览器小,传统网页的设计在手机上体验糟糕 Apple 在移动版 Safari 中定义了 viewport meta 标签(如果没记错最早提出的话),用于创建一个虚拟窗口(la ...
 - 移动端布局,C3新增属性
		
<html5拖拽> 1.给元素设置 draggable="true" 属性,这个元素就可以被拖拽了 <拖拽元素事件> 2.ondragstart 拖拽前触发 ...
 - 如何做好移动端的响应式设计:Viewport控制
		
新人翻译,欢迎转载~ 英文原文地址:http://bitsofco.de/2015/respove-design-viewport/ 原文例程地址:https://github.com/ireade/ ...
 - 移动端布局Demo展示图文
		
上两张图自勉一下(来自刘墉先生的文章,最近看他的作品):然后移动端该愈来愈受到重视,未来的市场我不知道,不过我知道手机的功能越来越强大是不争的事实!移动端布局的积累也需要从现在做起! 需求一:实现下图 ...
 - web移动端布局方式整理
		
写H5页面一直写的有点随意,只是保证了页面在各个屏幕下显示良好,却没有保证到在各个屏幕下是等比例放大或者缩小.这些天在写一些页面,试着看看能不能写出等比例放大缩小的页面,发现不容易啊,在网上找了一些文 ...
 - 移动端布局 - REM方式
		
默认以宽度为640px的设计稿为基准页面,然后通过JS获取当前显示设备的尺寸,对应的调整 html 标签的font-size大小,从而实现通过以rem为单位的移动端布局适配. 具体代码 (functi ...
 - Vuex里的module选项和移动端布局
		
Vuex里的modules 在store文件夹里创建一个modules的文件夹,里面随意创建一个.js文件,然后export输出
 - 页面自适应<meta name="viewport">标签设置
		
viewport: 它在页面中设置,是应对手机模式访问网站.网页对屏幕而做的一些设置.通常手机浏览器打开页面后,会把页面放在一个虚拟的“窗 口”–这个比窗口大,也就是你常发现页面可以进行拖动.放大放小 ...
 
随机推荐
- Makefile 简要辅导 【转载】
			
A Simple Makefile Tutorial Makefiles are a simple way to organize code compilation. This tutorial do ...
 - ELK6.3版本安装部署
			
一.Elasticsearch 安装 1.部署系统以及环境准备 cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core) uname - ...
 - C++统一初始化语法(列表初始化)
			
引言 要是世上不曾存在C++14和C++17该有多好!constexpr是好东西,但是让编译器开发者痛不欲生:新标准库的确好用,但改语法细节未必是明智之举,尤其是3年一次的频繁改动.C++带了太多历史 ...
 - Kubernetes 命令行工具之kubctl
			
目录 1.何为kubectl 2.Kubectl基本使用 2.1.命令补全 2.2.快速查找资源 2.3.使用自定义输出格式 3.陈述式管理资源 3.1.管理namespace资源 3.2.管理Dep ...
 - http请求返回的数字代表的含义
			
一些常见的状态码为: 200 - 服务器成功返回网页 404 - 请求的网页不存在 503 - 服务器超时 下面提供 HTTP 状态码的完整列表.点击链接可了解详情.您也可以访问 HTTP 状态码上的 ...
 - 移动App性能测评与优化1.4.4 多进程应用
			
1.4.4 多进程应用 根据上一节中的描述,当一个进程结束后,它所占用的共享库内存将会被其他仍然使用该共享库的进程所分担,共享库消耗的物理内存并不会减少.实际上,对于所有共享使用了这个库的应用,Pss ...
 - 为给定字符串生成MD5指纹
			
import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import org.apache ...
 - Centos7 搭建bind9.9
			
DNS服务器概述: DNS(Domain Name System),即域名系统. DNS服务器分为三种: 主域名服务器(Master Server).辅助域名服务器(Slave DNS).缓存服务器( ...
 - Spring官网阅读(十七)Spring中的数据校验
			
文章目录 Java中的数据校验 Bean Validation(JSR 380) 使用示例 Spring对Bean Validation的支持 Spring中的Validator 接口定义 UML类图 ...
 - leetCode刷题 | 两数相加
			
给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和 ...