viewport 的基本原理以及详细使用方法

所属分类: HTML/Xhtml / 网页制作 阅读数: 250
收藏 0 赞 0 分享

一.viewport的概要

移动端浏览器通常都在一个比屏幕更宽的虚拟窗口中渲染页面,这个虚拟窗口就是viewport,目的是正常展示没有做移动端适配的网页,可以让他们完整的展现给用户。我们有时用移动设备访问桌面版网页就会看到一个横向滚动条,这里可显示区域的宽度就是viewport的宽度。

常规使用,页面可以缩放就用下面的代码

<meta name="viewport" content="width=device-width, initial-scale=1" />

如果不想页面缩放就用下面的代码

<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">

二.css中的像素和设备像素的区别

在桌面网页开发时,css中的1px就是设备上的1px;然而css中的1px仅仅是一个抽象的值,不代表实际像素为多少;而在移动设备中,不同设备的像素密度是不一样的,css中的1px可能并不等于真实设备的一个像素值。用户缩放也会改变css中的1px代表多少设备像素。这个比例就是devicePixelRatio

物理像素/独立像素 = devicePixelRatio
我们可以在浏览器中进行缩放,在控制台中打印window.devicePixelRatio来查看devicePixelRatio的大小。其中的独立像素可以理解为css中的px。

三.视口基础

代码:

<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">

以下为viewport的几个属性,这些属性可以混合来使用,多个属性同时使用要用逗号隔开。这里我们展开一个概念,叫做ideal viewport,指的是理想情况下的viewport,不需要用户缩放和横向滚动条就能正常查看网页的所有内容,并且能够看清所有文字,无论这个文字在css中定义为多小,显示出来时可以看清的。

属性 描述
width 控制视口的宽度,可以指定数字;或设置device-width来指定
height 控制视口的高度,这个属性不太重要,很少使用
initial-scale 控制页面最初加载时的在在idealviewport下缩放等级,通常设为1,可以是小数
maximum-scale 允许用户的最大缩放值,为一个数字,可以带小数
minimum-scale 允许用户的最小缩放值,为一个数字,可以带小数
user-scalable 是否允许用户进行缩放,值为”no”或”yes”, no 代表不允许,yes代表允许

四.viewport进阶

1.width和initial-scale
当设置了width和initial-scale时,浏览器会自动选择数值最大的进行适配。如设置:

<meta name="viewport" content="width=400, initial-scale=1">

浏览器会选择数值大的进行适配,如果当前窗口ideal viewport宽度为300,initial-scale值为1,取得是width为400的值;如果当前窗口的ideal viewport为480,则取480。

事实上,width=device-width和initial-scale=1都代表应用ideal viewport,但在ipad、iphone等移动设备和IE上,横竖屏不分,默认都取竖屏的宽度,兼容性最好的写法就是

 <meta name="viewport" content="width=device-width, initial-scale=1">

2.动态改变属性

a. document.write()

document.write('<meta name="viewport" content="width=device-width,initial-scale=1">')

b.setAttribute

var mvp = document.getElementById('testViewport');
mvp.setAttribute('content','width=480');

viewport概念

移动端浏览器通常都在一个比屏幕更宽的虚拟窗口中渲染页面,这个虚拟窗口就是viewport,目的是正常展示没有做移动端适配的网页,可以让他们完整的展现给用户。我们有时用移动设备访问桌面版网页就会看到一个横向滚动条,这里可显示区域的宽度就是viewport的宽度。

css中的像素和设备像素的区别

在桌面网页开发时,css中的1px就是设备上的1px;然而css中的1px仅仅是一个抽象的值,不代表实际像素为多少;而在移动设备中,不同设备的像素密度是不一样的,css中的1px可能并不等于真实设备的一个像素值。用户缩放也会改变css中的1px代表多少设备像素。这个比例就是devicePixelRatio

物理像素/独立像素 = devicePixelRatio

我们可以在浏览器中进行缩放,在控制台中打印window.devicePixelRatio来查看devicePixelRatio的大小。其中的独立像素可以理解为css中的px。

视口基础
一个典型的针对移动端优化的站点包含类似下面的内容:

<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
 

以下为viewport的几个属性,这些属性可以混合来使用,多个属性同时使用要用逗号隔开。这里我们展开一个概念,叫做ideal viewport,指的是理想情况下的viewport,不需要用户缩放和横向滚动条就能正常查看网页的所有内容,并且能够看清所有文字,无论这个文字在css中定义为多小,显示出来时可以看清的。

属性 描述
width 控制视口的宽度,可以指定数字;或设置device-width来指定
height 控制视口的高度,这个属性不太重要,很少使用
initial-scale 控制页面最初加载时的在在idealviewport下缩放等级,通常设为1,可以是小数
maximum-scale 允许用户的最大缩放值,为一个数字,可以带小数
minimum-scale 允许用户的最小缩放值,为一个数字,可以带小数
user-scalable 是否允许用户进行缩放,值为”no”或”yes”, no 代表不允许,yes代表允许

viewport进阶

1.width和initial-scale
当设置了width和initial-scale时,浏览器会自动选择数值最大的进行适配。如设置:

<meta name="viewport" content="width=400, initial-scale=1">

浏览器会选择数值大的进行适配,如果当前窗口ideal viewport宽度为300,initial-scale值为1,取得是width为400的值;如果当前窗口的ideal viewport为480,则取480。

事实上,width=device-width和initial-scale=1都代表应用ideal viewport,但在ipad、iphone等移动设备和IE上,横竖屏不分,默认都取竖屏的宽度,兼容性最好的写法就是

<meta name="viewport" content="width=device-width, initial-scale=1">

2.动态改变属性

a. document.write()

document.write('<meta name="viewport" content="width=device-width,initial-scale=1">')

b.setAttribute

var mvp = document.getElementById('testViewport');
mvp.setAttribute('content','width=480');

好了,这篇文章就介绍到这了大家可以根据自己测需要要选择。一般来说pc与移动不带自适应的就可以用不支持缩放的,如果跳转到移动端的可以缩放也没有影响。

更多精彩内容其他人还在看

Html屏蔽右键菜单和左键划字功能的示例

禁止右键菜单<body oncontextmenu=self.event.returnValue=false>禁止左键划字复制<body onselectstart="return false">采用CSS来控制是否可以选择文字.uns... 查看详情
收藏 0 赞 0 分享

html+css+js 实现拍照预览上传图片功能

前言:我们在做网页时经常会需要有上传图片的需求,可能是选择图片或者拍照上传,如果简单的使用<input type="file"/>这种方式虽然也能实现功能,但用户体验上可能会差了一些,所以本文记录了使用css+js实现图片选中后的预览及压缩上传功能... 查看详情
收藏 0 赞 0 分享

HTML阻止iframe跳转页面并使用iframe在页面内嵌微信网页版的实现方法

就想弄一个winform结合html5的一个小东西,突有兴致,想在里面嵌套一个微信网页版。好了,想法一出来,就行动吧,最终效果如下图:一开始就打算在页面里面嵌套一个iframe指向https://wx.qq.com就OK了,但是我还是太天真,微信网页版会自动跳转。结果如下图:于是... 查看详情
收藏 0 赞 0 分享

详解HTML常用的标签中行内元素和块级元素

块元素(block element) HTML标签分类明细     * address - 地址     * blockquote - 块引用     * center - 举中对... 查看详情
收藏 0 赞 0 分享

解决移动端跳转问题(CSS过渡、target伪类)

前言很多刚刚接触移动端的小伙伴都可能对于点击跳转路由这方面有些疑惑,特别是运用了Vue路由,因此这篇文章就带领小伙伴一起尝试用css进行页面跳转效果如图,由于是移动端,所以选择预览的手机模拟:HTML <body> <main> ... 查看详情
收藏 0 赞 0 分享

浅谈HTML中src和href之间的区别

简单来说 src 就是 “我想加载这个资源”,而 href 就是 “我想和这个资源建立关联”src 主要用于元素替换,href 用于和相关文档和外部资源建立相关链接。href 属性说明本地Web资源和定义的资源建立了链接。如:<... 查看详情
收藏 0 赞 0 分享

HTML中的if判断用法

在django的web开发过程中,编写html时,从后端传入同名列表变量,但是内容格式有所区别,需要分别判断,查阅了很多文章试了好几种方法,格式似乎都不太对(本人没有系统学习过前端,基本都是照葫芦画瓢)后来找到django框架下html的if用法形式大致如下  ... 查看详情
收藏 0 赞 0 分享

详解html的几种水平垂直居中的方式(基础)

前言我们在编写马过程中,想必大家对水平垂直居中的方法了解并不多。所以我给大家总结式的列出几种常用的水平垂直居中的方法。第一种方法<!--html盒子代码--><!--水平垂直居中--><div class="Centered1"&... 查看详情
收藏 0 赞 0 分享

纯css实现(无脚本)Html指令式tooltip文字提示效果

 分析执行流程 鼠标移入节点 检测是该节点是否存在开启实现 tooltip 实现的标识(类名,属性等) 检测主题、位置(类名,属性等) 生成 / 显示气泡 借鉴他人让我们先来看看 element-ui的tooltip 样式很明显, 气泡的位置 是通过 javascrip... 查看详情
收藏 0 赞 0 分享

Markodwn 标题对齐的同步滚动实现思路详解

前言需要给正在写的Markodwn编辑器加上同步滚动的功能,百度了一通,没找到比较好的思路。就自己写了一个。Github上是写好的库,和更直观的Demo。Github这篇文章主要讲的是实现的思路。介绍同步滚动的实现方式有很多种。简单粗暴的就直接让 HTMLElement.scro... 查看详情
收藏 0 赞 0 分享
查看更多