HTML的meta viewport属性应该如何使用

这次给大家带来htmlmeta viewport属性应该如何使用,使用html的meta viewport属性注意事项有哪些,下面就是实战案例,一起来看一下。

什么是Viewport
手机浏览器是把页面放在一个虚拟的“窗口”(viewport)中,通常这个虚拟的“窗口”(viewport)比屏幕宽,这样就不用把每个网页挤 到很小的窗口中(这样会破坏没有针对手机浏览器优化的网页的布局),用户可以通过平移和缩放来看网页的不同部分。移动版的 Safari 浏览器最新引进了 viewport 这个 meta tag,让网页开发者来控制 viewport 的大小和缩放,其他手机浏览器也基本支持。
Viewport 基础
一个常用的针对移动网页优化过的页面的 viewport meta 标签大致如下:


width:控制 viewport 的大小,可以指定的一个值,如果 600,或者特殊的值,如 device-width 为设备的宽度(单位为缩放为 100% 时的 CSS 的像素)。
height:和 width 相对应,指定高度。
initial-scale:初始缩放比例,也即是当页面第一次 load 的时候缩放比例。
maximum-scale:允许用户缩放到的最大比例。
minimum-scale:允许用户缩放到的最小比例。
user-scalable:用户是否可以手动缩放
关于viewport的一些问题
viewport并非只是ios上的独有属性,在android、winphone上同样也有viewport。它们要解决的问题是相同的,即无视设备的 真实分辨率,直接通过dpi,在物理尺寸和浏览器之间重设分辨率,这个分辨率和设备的分辨率无关。比如,你拿个3.5寸-320 * 480的iphone3 gs、3.5寸-640 * 960的iphone4或者9.7寸-1024*768的ipad2,虽然设备的分辨率不同,物理尺寸也不同,但你可以通过设置viewport让它们在 浏览器里有相同的分辨率。比如说,你的网站是800px宽,你可以通过设置viewport的width=800,来让你的网站在这三个不同的设备上都刚 好满屏显示你的网站。
以上的知识,相信每个对viewport稍有了解的同学应该都已经了解了。这不是我今天想说的重点。我想说明的是viewport在ios和android上的一些差异表现。
网上一搜关于viewport的知识,基本上全都是如下信息:


这段代码的意思是,让viewport的宽度等于物理设备上的真实分辨率,不允许用户缩放。一都主流的web app都是这么设置的,它的作用其实是故意舍弃viewport,不缩放页面,这样dpi肯定和设备上的真实分辨率是一样的,不做任何缩放,网页会因此显 得更高细腻。玩ps的同学应该都知道,当你将一张1000 * 1000的图片直接缩放至500 * 500分变成什么样,对吧?图片的失真一定逃不掉。
但我要做的一个应用却恰恰相反,需要利用viewport,利用缩放。不论真实分辨率是多少,无论物理尺寸是多少,我都希望在浏览器里,能有统一的分辨 率,同时也不允许用户缩放。我用来测试的设备有:iphone4、ipad2、htc的g11、不知道什么厂商的aquos phone(android系统)、华硕的android pad、dell的winphone然后我一路遇到了如下问题:
1)如果不显示地设置viewport,那么width的默认为980。如果页面的所有元素宽度都小于980,此时width为980,如果页面最 宽的位置超过980,那么width等于最大宽度。总之,默认能将整个页面从左到右显示出来。如果设置了viewport,比如,只单纯地设置了 user-scalable=no,例如,那么ios下width还是按980显示(即默认就会通过dpi缩放),但android和winphone下却不会再缩放了,浏览器分辨率 和真实设置分辨率一致。 

2)对于ios设备,设置width可以生效,但对于android,设置width并不会生效。ios设备,缩放的比率即dpi是通过你设置的 width和设置真实分辨率自动计算的,而android下你设置width无效,你能设置的是一个特殊的字段target-densitydpi,关于 target-densitydpi可以参考一下这篇文章:http://hi.baidu.com/j_fo/blog/item /748361279ebccd18908f9d7d.html。也就是说,有三个变量:浏览器width、设备真实width、dpi。 我们简单地用个公式来表达它们之间的关系吧(并非真实关系,简单说明用) 设备真实width * dpi = 浏览器width,这里的三个变量,设备真实width是个我们不能操作的已知值,另外两个变量我们可以设置一个来影响另一个,在ios中,我们能改的是 浏览器width,dpi自动生成,而在android中,我们能改的是dpi,浏览器width自动生成。对于android,无论我们如何设置 width,也不会对浏览器width产生影响。

ps:这里我另外再说一个奇怪的问题:在htc的g11里(htc的手机我只有这一个,别的没有测),如果设置了dpi而不显示地设置width, 则user-scalable=no不生效,即是说:,无法阻止用户缩放屏幕。我们需要显示地设置一下width值,仅管这个值对android下的浏览器分辨屏并不产生任何影响(对ios还是会 产生影响的),我们仍然要设置它,而且这个值一定要大于320,如果小于等于320,也无法使user-scalable=no生效。这个问题只在htc 的g11手机上出现,在aquos phone没有这个问题。兼容android真是件头痛的事 @_@,未来还不知道有多少坑呢。而在winphone上,结果就更奇怪了:我给viewport的width设一个大于480的值,user- scalable=no就失效了,而设一个小于480的值,user-scalable=no能生效。但无论我给viewport的width设多少值, 对winphone真正显示的width却并不产生我预期的影响,通过target-densitydpi也没有影响。设置width,如果小于480的 话,屏幕会缩放,但缩小的比例却和我预期完全不一样,我不知道它是按照什么规律缩放的。不知道这是winphone的问题,还是dell实现的问题。

3)这一条和上一条应该是直接相关的:ios设备在横竖屏时,会自动调整dpi,无论横屏还是竖屏,都能保证浏览器width等于viewport 中设置的值,所以横竖屏的时候,页面里显示的内容的大小是会自动缩放产生变化的。而android手机在横竖屏的时候,不会改变dpi,在横竖屏的时候, 网页不会产生缩放。也正因此,ios可以保证横竖屏页面都不会产生滚动条,满屏显示,而android却无法保证这一点,横着满屏则竖着无法满屏,反之亦 然。

4)对于ios设备,如果width显示定义了,而页面最宽的位置超过width的话,width无效,仍按最宽的宽度来显示(不会有滚动条)。但 此时会出现一个很奇怪的问题,当你将手机横竖屏切换几次之后,会发现你的页面自动放大了,出现了滚动条,但其实放大后的宽度其实和你设的width也并没 有关系。为了防止这种情况出现,你需要将width的宽度设置得比页面最宽的地方更大,或者相同。 

立即学习“前端免费学习笔记(深入)”;

相信看了这些案例你已经掌握了方法,更多精彩请关注创想鸟其它相关文章!

相关阅读:

怎样实现手机自适应网页的大小

在HTML里的hr水平线应该如何使用

以上就是HTML的meta viewport属性应该如何使用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1545785.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 17:24:59
下一篇 2025年12月21日 17:25:19

相关推荐

  • 学会从头开始学习CSS,掌握制作基本网页框架的技巧

    从零开始学习CSS,掌握网页基本框架制作技巧 前言: 在现今互联网时代,网页设计和开发是一个非常重要的技能。而学习CSS(层叠样式表)是掌握网页设计的关键之一。CSS不仅可以为网页添加样式和布局,还可以为用户呈现独特且具有吸引力的页面效果。在本文中,我将为您介绍一些基本的CSS知识,以及一些常用的代…

    2025年12月24日
    200
  • 揭秘Web标准涵盖的语言:了解网页开发必备的语言范围

    在当今数字时代,互联网成为了人们生活中不可或缺的一部分。作为互联网的基本构成单位,网页承载着我们获取和分享信息的重要任务。而网页开发作为一门独特的技术,离不开一些必备的语言。本文将揭秘Web标准涵盖的语言,让我们一起了解网页开发所需的语言范围。 首先,HTML(HyperText Markup La…

    2025年12月24日
    000
  • 揭开Web开发的语言之谜:了解构建网页所需的语言有哪些?

    Web标准中的语言大揭秘:掌握网页开发所需的语言有哪些? 随着互联网的快速发展,网页开发已经成为人们重要的职业之一。而要成为一名优秀的网页开发者,掌握网页开发所需的语言是必不可少的。本文将为大家揭示Web标准中的语言大揭秘,介绍网页开发所需的主要语言。 HTML(超文本标记语言)HTML是网页开发的…

    2025年12月24日
    400
  • 常用的网页开发语言:了解Web标准的要点

    了解Web标准的语言要点:常见的哪些语言应用在网页开发中? 随着互联网的不断发展,网页已经成为人们获取信息和交流的重要途径。而要实现一个高质量、易用的网页,离不开一种被广泛接受的Web标准。Web标准的制定和应用,涉及到多种语言和技术,本文将介绍常见的几种语言在网页开发中的应用。 首先,HTML(H…

    2025年12月24日
    000
  • 网页开发中常见的Web标准语言有哪些?

    探索Web标准语言的世界:网页开发中常用的语言有哪些? 在现代社会中,互联网的普及程度越来越高,网页已成为人们获取资讯、娱乐、交流的重要途径。而网页的开发离不开各种编程语言的应用和支持。在这个虚拟世界的网络,有许多被广泛应用的标准化语言,用于为用户提供优质的网页体验。本文将探索网页开发中常用的语言,…

    2025年12月24日
    000
  • 深入探究Web标准语言的范围,涵盖了哪些语言?

    Web标准是指互联网上的各个网页所需遵循的一系列规范,确保网页在不同的浏览器和设备上能够正确地显示和运行。这些标准包括HTML、CSS和JavaScript等语言。本文将深入解析Web标准涵盖的语言范围。 首先,HTML(HyperText Markup Language)是构建网页的基础语言。它使…

    2025年12月24日
    000
  • CSS 超链接属性解析:text-decoration 和 color

    CSS 超链接属性解析:text-decoration 和 color 超链接是网页中常用的元素之一,它能够在不同页面之间建立连接。为了使超链接在页面中有明显的标识和吸引力,CSS 提供了一些属性来调整超链接的样式。本文将重点介绍 text-decoration 和 color 这两个与超链接相关的…

    2025年12月24日
    000
  • 如何使用 CSS Viewport 单位来实现根据屏幕尺寸调整边距的技巧

    使用 CSS Viewport 单位来实现根据屏幕尺寸调整边距的技巧 在网页开发中,响应式设计已经成为一种必备技能。根据不同设备的屏幕尺寸来适应网页布局,是提升用户体验的重要手段之一。CSS Viewport 单位就是用来帮助我们实现这个目标的工具之一。本文将介绍如何使用 CSS Viewport …

    2025年12月24日
    000
  • CSS Viewport: 使用 vw 和 vmin 创建自适应文字大小的方法

    CSS Viewport: 使用 vw 和 vmin 创建自适应文字大小的方法 在开发响应式网站时,经常会碰到需要根据不同设备尺寸来调整文字大小的需求。CSS Viewport单位是一种实现此目的的强大工具,而其中的 vw 和 vmin 单位特别适合用来创建自适应文字大小的效果。 Viewport …

    2025年12月24日
    000
  • 使用 CSS Viewport 单位 vh 和 vw 创建全屏背景图像的方法

    使用 CSS Viewport 单位 vh 和 vw 创建全屏背景图像的方法,需要具体代码示例 随着移动设备和响应式设计的流行,全屏背景图像成为了设计中常见的要素。传统的方法是使用 JavaScript 或者 jQuery 来实现,但是现在可以利用 CSS Viewport 单位 vh 和 vw 来…

    2025年12月24日
    000
  • 如何使用 CSS Viewport 单位 vh 来创建适配手机屏幕的网页布局

    如何使用 CSS Viewport 单位 vh 来创建适配手机屏幕的网页布局 手机设备的普及和使用越来越广泛,越来越多的网页需要进行手机屏幕的适配。为了解决这个问题,CSS3引入了一个新的单位——Viewport单位,其中包括vh (viewport height)。在这篇文章中,我们将探讨如何使用…

    2025年12月24日
    000
  • 使用 CSS Viewport 单位 vh 和 vmin 创建媒体查询的技巧

    使用 CSS Viewport 单位 vh 和 vmin 创建媒体查询的技巧 随着移动设备的普及,响应式设计已成为现代网页设计的必备技术。为了适应不同大小的屏幕,开发人员需要通过媒体查询来调整布局和样式。而在媒体查询中,最常用的单位是像素(px)。然而,CSS3引入了一种新的视窗单位,即vh和vmi…

    2025年12月24日
    000
  • CSS Viewport 单位 vmin 和 vmax: 如何实现根据屏幕尺寸调整元素间距的方法

    CSS Viewport 单位 vmin 和 vmax: 如何实现根据屏幕尺寸调整元素间距的方法,需要具体代码示例 在响应式设计中,让网页在不同设备上都能良好地呈现是非常重要的。CSS 提供了一些单位和技巧来帮助我们根据屏幕尺寸调整元素的间距。其中,单位 vmin 和 vmax 可以根据视口的尺寸进…

    2025年12月24日
    000
  • CSS Viewport: 如何使用 vh、vw、vmin 和 vmax 单位来实现响应式设计

    CSS Viewport: 如何使用 vh、vw、vmin 和 vmax 单位来实现响应式设计,需要具体代码示例 在现代响应式网页设计中,我们通常希望网页能够适应不同屏幕尺寸和设备,以提供良好的用户体验。而CSS Viewport单位(视口单位)就是帮助我们实现这一目标的重要工具之一。在本文中,我们…

    2025年12月24日
    000
  • 如何使用 CSS Viewport 单位 vw 来实现水平自适应布局

    如何使用 CSS Viewport 单位 vw 来实现水平自适应布局 CSS Viewport 是一种相对于视口宽度的单位,可以通过它来创建响应式的布局。其中,vw 即代表视口宽度的百分比单位。 在这篇文章中,我们将学习如何使用 CSS Viewport 单位 vw 来实现水平自适应布局,并且提供具…

    2025年12月24日
    000
  • CSS Viewport: 使用 vh 和 vmax 创建自适应屏幕高度的方法

    CSS Viewport: 使用 vh 和 vmax 创建自适应屏幕高度的方法 在现代网页设计中,自适应布局已经成为一种必备的技术。由于不同设备的屏幕尺寸和分辨率各不相同,如何实现页面在各种设备上的良好显示成为了一个挑战。 在CSS中,Viewport是一个用于控制网页布局和显示的重要元素。View…

    2025年12月24日
    000
  • 如何使用 CSS Viewport 单位来实现自适应背景图像

    如何使用 CSS Viewport 单位来实现自适应背景图像 背景图像在网页设计中起着非常重要的作用,可以为网页增添美感和吸引力。然而,由于不同设备和屏幕尺寸的存在,使得如何实现自适应背景图像成为了一个挑战。在本文中,我们将介绍如何使用 CSS Viewport 单位来实现自适应背景图像,并给出具体…

    2025年12月24日
    000
  • 如何使用 CSS Viewport 单位 vh 和 vw 来实现适应不同屏幕高度布局

    如何使用 CSS Viewport 单位 vh 和 vw 来实现适应不同屏幕高度布局 随着移动设备的普及,许多网站和应用程序需要在不同屏幕高度上能够良好呈现。CSS提供了一系列单位,其中vh(视区高度)和vw(视区宽度)单位非常适合用于适应不同屏幕高度的布局。本文将详细介绍如何使用这两个单位以及提供…

    2025年12月24日
    000
  • CSS Viewport: 如何使用 vmax 和 vw 来实现自适应文字宽度的方法

    CSS Viewport: 如何使用 vmax 和 vw 来实现自适应文字宽度的方法 随着移动设备的普及,响应式设计已经成为了网页设计的重要概念。其中,自适应文字宽度在不同屏幕尺寸下保持一致的显示效果是一项重要的技术。本文将介绍如何使用 CSS Viewport 单位,特别是 vmax 和 vw 单…

    2025年12月24日
    000
  • 看看这些前端面试题,带你搞定高频知识点(一)

    每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!,在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。 面试官:给定一个元素,如何实现水平垂直居中?…

    2025年12月24日 好文分享
    300

发表回复

登录后才能评论
关注微信