Vh和Vw的简介和使用

Vw:视区宽度百分值

Vh:视区高度百分值

Vmin:取Vw或Vh中较小的那一个

Vmax:取Vw或Vh中较大的那一个

1.视区:是指浏览器内部的可视区域大小,即window.innerWidth/window.innerHeight大小,不包含任务栏标题栏以及底部工具栏的浏览器区域大小

2.场景之元素的尺寸限制

我们应该都做过或见过这样的交互:点击下图,弹框查看原始大图;或者一屏内(不能有滚动条)大图幻灯片浏览。这类需求让人头疼的地方之一就是原始大图的尺寸限制问题——因为很有可能图片过大,尼玛一屏显示器区域不够放,我们需要对其进行缩放处理。这类限制的实现,在当下,需要获得图片的原始大小,以及浏览器内部尺寸,算大小,算比例等,算是比较折腾的。但是,vw, vh等单位本身就是浏览器视区大小相关单位,直接使用其做限制,岂不省了N多JS代码??img { max-height: 90vh; }
这里写图片描述

3.基于vw的响应式排版和布局

一般而言,屏幕越大,我们希望文字大小也越大,元素的尺寸也能等比例放大,尤其在现在的网页设计风格中。

如果要实现这种弹性自适应效果,目前主流的实现是通过设定根元素的font-size大小,具体元素或模块使用rem或em单位来实现。
一种是直接设定一个临界点字体大小,如:
这里写图片描述
还有一种就是使用JS在resize或者屏幕旋转的时候,动态修改root的font-size大小。

前面一种基于@media的CSS实现问题在于,内容的弹性自适应只会在临界点的时候,“Duang”变化下,于是,我们浏览器尺寸拉伸的时候,会感受到类似“噔噔噔”卡壳的效果,感觉就像是吃了含笑半步癫,使用JS的问题在于他是JS,要保证加载体验,需要头部内联,为了保证实时性,需要多个浏览器变化事件监测,用我的口头禅讲就是“显得啰嗦”。
那有没有两全其美的方法呢?

有,那就是本文要隆重请出场的vw,配合CSS3 calc计算实现动态字体大小效果。

例如,我们希望浏览器宽度在600px~1000px变化的时候,html根元素的font-size大小是18px~22px之间对应变化的,则可以:
这里写图片描述
于是,理论上,一个18px~22px字体大小动态匹配的布局基础就建好了。

一般出现“理论上”这三个字,就说明我要“放坑”了,大家闪开~~

此“坑”就是苹果系统的Safari浏览器不认识上面的属性值(如下截图):
这里写图片描述
就Safari不行,window下的所有浏览器,包括IE,以及mac下的Chrome等浏览器都是可以正确解析的。好在,我们还是有办法曲线救国的。那就是,我们基础字体大小不使用像素单位,使用百分比单位即可,如下:
这里写图片描述
有个动态的根字体大小,我们就可以使用rem或em这些相对单位,来让我们的页面排版和布局更富有弹性。
更新于2017年2月8日
经过大型项目实践,下面这段CSS是最好的基于rem和vm和calc实践代码:
这里写图片描述
然后,就可以愉快地使用rem单位用来排版和布局啦!

每当我疑惑的时候,我不是去找个“我觉得应该是”的解释,而是,新建个HTML页面,像学生时代做生物实验般,多条件对比验证之

多花点功夫,多些想法(感性认知,如果这样……或者那样……),多实践实践(制作demo),多总结总结(写作),再深入延伸延伸(水平方向流体布局 → 水平时间轴);久而久之,水平自然大幅提升,瓶颈自然会突破

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407736.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

处理后台返回文本带空格和换行页面不显示断句的问题

有时候接口返回文本数据是空格分开或者手动换行分开的,在页面上显示成一堆,只要在该节点上加上css 文本段落换行 white-space: pre-wrap;

江民杀毒软件KV网络版反病毒整体解决方案──金融行业

江民杀毒软件KV网络版反病毒整体解决方案──金融行业江民杀毒软件KV网络版反病毒整体解决方案──金融行业 金融行业是对信息化要求程度极高的行业。它需要一个高效、安全的网络环境来保证信息处理系统能正常有效运行。但随着信息化的应用面越来越广,信息安全…

Linux和Windows下查看、设置环境变量的比较

[一]查看环境变量: 1.windows 查看所有的变量:set 范例:>set 查看某个变量的值:set 环境变量名 范例: >set JAVA_HOME JAVA_HOMED:\jdk 2.linux 查看所有的变量:export 范例:export 查看某…

2014/5/25 多校

A: 1 #include<iostream>2 #include<stdio.h>3 #include<string.h>4 #include<set>5 #define maxn 58*3000006 using namespace std;7 8 set<int>S;9 int Enum0,score[maxn],son[maxn][26],l[maxn];10 bool flag[maxn];//标记是否打星11 int to…

margin:auto实现绝对定位元素的水平垂直居中

1.绝对定位元素的居中实现的一般方法 兼容性不错的主流用法是&#xff1a; 但&#xff0c;这种方法有一个很明显的不足&#xff0c;就是需要提前知道元素的尺寸。否则margin负值的调整无法精确。此时&#xff0c;往往要借助JS获得。 CSS3的兴起&#xff0c;使得有了更好的…

swiper 滑动出现闪白

滑动swiper时&#xff0c;swiper里面的元素会发生闪白的情况。 解决方法&#xff1a;给外部元素的父标css套一个&#xff08;swiper-container&#xff09; .swiper-container{transform:translate3d(0,0,0); }闪动元素/子元素&#xff08;swiper-slide&#xff09; .swiper…

MCSE2003学习之一

MCSE2003之2276&#xff1a;实现2003网络结构&#xff0c;网络主机TCP/IP协议的结构一&#xff1a;OSI模型计算机网络的形成促使网络协议的成熟。IBM在1974年提出了SNA网络协议二&#xff1a;分层模型的网络体系1&#xff1a;OSI/RM开放系统互联ApplicationPresentationSession…

Linux和windows中的换行符差异问题 LINUX的换行符在Windows记事本打开不换行或出现黑点

http://hi.baidu.com/mayongl7/blog/item/06e61af7c719053a730eec4d.html LINUX的换行符在Windows记事本打开不换行或出现黑点 是由于Linux和windows中的换行符差异问题造成的。 首先来看回车符号和换行符号产生背景 关于“回车”&#xff08;carriage return&#xff09;和“换…

x:Name与Name区别

x:Name与Name有两个不同点&#xff1a; 1、x:Name是Xaml的标记特性&#xff0c;任何在Xaml中定义的元素&#xff0c;都可以使用x:Name来为元素指定名称。 Name是FrameworkElement定义的依赖项属性&#xff08;String类型&#xff09;&#xff0c;只有FrameworkElement的派生类才…

CSS的包裹性

什么是包裹性&#xff1f; 包裹性就是父元素的宽度会收缩到和内部元素宽度一样。 哪些元素具有包裹性&#xff1f; 就我已知的有&#xff1a;absolute&#xff0c;fixed&#xff0c;float&#xff0c;inline-block&#xff0c;inline-flex&#xff0c;table-cell等等 应用场…

vue监听滚动开始与结束

data{ oldScrollTop: 0, //记录上一次滚动结束后的滚动距离 scrollTop: 0 ,// 记录当前的滚动距离 }watch: {scrollTop(newValue, oldValue) {setTimeout(() > {if(newValue window.scrollY) { //延时执行后当newValue等于window.scrollY&#xff0c;代表滚动结束console.l…

Pro*C 中嵌入pl/sql块

From: http://blog.csdn.net/zistxym/article/details/5054066 /* 包含C头文件 */ #include <stdio.h> #include <string.h> #include <stdlib.h> /* 包含SQLCA头文件 */ EXEC SQL INCLUDE sqlca; EXEC SQL INCLUDE sqlda; int main() { EXEC SQL BEG…

程序员是一盏省油的灯

新太科技商业泄密事件&#xff0c;引发作者万千感慨&#xff0c;本文是《新太科技商业泄密事件背后的思考》系列之四。加班是程序员的家常便饭&#xff0c;八小时工作制几成笑谈&#xff0c;在软件公司的眼里&#xff0c;程序员只是一架会思考的机器&#xff0c;是一盏省油的灯…

[译]第三章:什么是组织结构

组织结构有这自己的特性&#xff0c;一方面结构的作用是保持稳定&#xff0c;只有稳定的结构才可能产生效率&#xff0c;但是发展又需要结构变化&#xff0c;只有变化的结构才会带来发展&#xff1b;&#xff08;一&#xff09;组织结构是自我约定的关系&#xff1a;&#xff0…

:after伪类+content内容清除浮动

1.简单说说content内容生成 content内容生成就是通过content属性生成内容 例如下面这个简单的例子&#xff1a; 此段样式的作用是在每个h2标签的前面添加文字“我是额外文字”。 2.:after伪类content 清除浮动的影响 有点经验的同行应该知道&#xff0c;一般不含包裹属性…

图片宽高自动适配

一些长宽比不同的图片适应盒子&#xff0c;我们往往用js获取图片宽高&#xff0c;得到宽高谁长&#xff0c;让长边100%。 其实用css就可以解决,这样无论长边是谁都能适配屏幕了 img{ max-width:100%&#xff1b; max-height:100%; }

Pro*c源程序中使用宿主结构保存查询结果

开发环境&#xff1a;VC6 XP Oracle10 Pro*c源程序如下&#xff1a; /*功能&#xff1a;演示了在pro*c源程序中使用结构体(宿主结构)来保存查询结果使用宿主结构的注意事项1. 结构成员的数据类型、顺序必须与内嵌SQL语句中列的数据类型和顺序匹配2. 宿主结构与PL/SQL的记录类…