vue自定义html布局,vue的自定义布局(vm/vh)

目录

1. px与视口

2. %

3. 媒体查询

4. rem

5. vm/vh

1. vw/vh的定义

css3中引入了一个新的单位vw/vh,与视图窗口有关,vw表示相对于视图窗口的宽度,vh表示相对于视图窗口高度,除了vw和vh外,还有vmin和vmax两个相关的单位。各个单位具体的含义如下:

这里我们发现视窗宽高都是100vw/100vh,那么vw或者vh,下简称vw,很类似百分比单位。vw和%的区别为:

从对比中我们可以发现,vw单位与百分比类似,单确有区别,前面我们介绍了百分比单位的换算困难,这里的vw更像"理想的百分比单位"。

任意层级元素,在使用vw单位的情况下,1vw都等于视图宽度的百分之一。

2. vw单位换算

如果要将px换算成vw单位,只要确定视图的窗口大小(布局视口),如果我们将布局视口设置成分辨率大小。

比如对于iphone6/7 375*667的分辨率,那么px可以通过如下方式换算成vw:

1px = (1/375)*100 vw

此外,也可以通过postcss的相应插件,预处理css做一个自动的转换,postcss-px-to-viewport可以自动将px转化成vw。 postcss-px-to-viewport的默认参数为:

var defaults = {

viewportWidth: 320,

viewportHeight: 568,

unitPrecision: 5,

viewportUnit: 'vw',

selectorBlackList: [],

minPixelValue: 1,

mediaQuery: false

};

通过指定视窗的宽度和高度,以及换算精度,就能将px转化成vw。

3. vw/vh单位的兼容性

可以在https://caniuse.com/ 查看各个版本的浏览器对vw单位的支持性。

我们发现,绝大多数的浏览器支持vw单位。

4. vh 下载插件 postcss-viewport-units 时,使用使用伪类选择器遇到的问题

module.exports = {

"plugins": {

"postcss-import": {},

"postcss-url": {},

// to edit target browsers: use "browserslist" field in package.json

// "autoprefixer": {},

"postcss-aspect-ratio-mini": {},

"postcss-write-svg": {

utf8: false

},

"postcss-cssnext": {},

"postcss-px-to-viewport": {

// 视窗的宽度,对应的是我们设计稿的宽度,移动端一般是750,如果是pc端那就是类似1920这样的尺寸

viewportWidth: 1920,

viewportHeight: 1080, // 视窗的高度,也可以不配置

unitPrecision: 3, // 指定`px`转换为视窗单位值的小数位数(很多时候无法整除)

viewportUnit: 'vw', // 指定需要转换成的视窗单位,建议使用vw

// 过滤掉不转换为视窗单位的class类名,可以自定义,可以无限添加,建议定义一至两个通用的类名

selectorBlackList: ['.ignore', '.hairlines'],

minPixelValue: 1, // 小于或等于`1px`不转换为视窗单位,你也可以设置为你想要的值

mediaQuery: false // 允许在媒体查询中转换`px`

},

"

"postcss-viewport-units":{

filterRule: rule => rule.selector.indexOf('::after') === -1 &&

rule.selector.indexOf('::before') === -1 &&

rule.selector.indexOf(':after') === -1 &&

rule.selector.indexOf(':before') === -1

},

"cssnano": {

preset: "default", // 设置成default将不会启用autoprefixer

"postcss-zindex": false

}

}

}

使用 vh 后,会给每个普通div标签加上 content 属性,但是如果在伪类选择器上加上 content ,会显示出来,设置过滤函数会规避掉::after ::before等。

使用 vw/vh 布局实现自适应优于其他方案,能够完美的解决调屏幕自适应问题

本文地址:https://blog.csdn.net/AyayaOVO/article/details/107290366

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

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

相关文章

Memcached 缓存个体,对象,泛型,表

最近,为提高数据查询速度,想做点缓存,通过网上了解,觉得,最好使用的就是Memcached;下面简单给大家介绍下Memcached; 下面是两位大牛关于Memcached的介绍;大家可以看看 http://zhoufo…

C# 语言特性

Codeusing System;using System.Collections.Generic;using System.Text;namespace InterfaceShadow{ interface ISomeInterface { void DoSomething(); } class Class1 : ISomeInterface { #region ISomeInterface 成员 public void DoSo…

北方人的快乐。。。| 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅(视频来源 最走心的视频,侵权删)

游国色天香中国馆有感

游国色天香中国馆有感——代腾飞 2007年9月16日 于成都漫步花丛望楼亭湖上泛舟烟雨行中国山河多绣丽怎叫诗人不生情

微型计算机c560,2010广东省计算机等级考试试题 二级C试题最新考试试题库

1、办公自动化是计算机的一项应用,按计算机应用的分类,它属于( C )A、科学计算 B、实时控制 C、数据处理 D、辅助设计2、计算机最主要的工作特点是( A )A、程序存储与自动控制 B、高速度与高精度C、可靠性与可用性 D、有记忆能力3、一般情况下&#xff0…

如何掌握C#的核心技术

如何掌握C#的核心技术原图来自网络,如有侵权,请联系小编删除。引子前不久看到一个段子,某年宁波交警引进人脸识别技术抓拍行人闯红灯,结果一天下来被发现闯红灯次数最多的是珠海女子董小姐,日闯红灯3000多次。宁波交警…

Zend_Feed 的项目实际应用

author songfengRSS0.9/1.0/2.0 ATOM 全部是内容聚合的应用,优点一是浏览者可以订阅其网站,能收到最新的网站更新内容.二是有利于搜索引擎抓取.个人感觉缺点是会被其它网站当成复制品,批量 抓取网站更新内容&…

mysqldump 的常用参数。

mysqldump 常用参数详解:--databases:备份多个数据库,选项后跟多个库名。备份文件中会包含USE db_name。--events : 备份事件--routines:备份存储过程和函数--ignore-tableTableName :指定不需要备份的表--tables:…

怪咖发明家,乔布斯给了他四亿,他没要,转身靠发明救了10亿人。

全世界只有3.14 %的人关注了青少年数学之旅提到乔布斯,大家会想到什么呢?苹果公司创始人?iPhone手机?iPad?人生赢家?不过大家肯定没有想到乔布斯也有吃瘪的时候:有一次,乔布斯对电动平衡车赛格…

西北纺织工学院97级计算机系学生毕业名单,原西北纺织工学院更名为西安工程大学...

原西北纺织工学院,曾更名为西安工程科技学院,2006年2月更名为西安工程大学。西北纺织工学院位于世界闻名的历史文化古都西安市,是中国纺织总会直属高等院校,也是我国西北和西南地区唯一的一所纺织高等学府,担负着培育纺…

祝贺|合肥.NET俱乐部第二期技术沙龙活动圆满成功

热烈祝贺合肥.NET俱乐部第二期技术沙龙圆满成功,感恩参与活动的每一位小伙伴!正是因为有你们才促成了这次聚会的成功。现对此次活动进行简单回顾并附上精彩的活动图片,每一位参与活动者名单,以及此次活动讲师分享的PPT供大家学习下…

几个常用的JS代码.

//函数列表function PostCookie(cookieName) { var expdate new Date(); expdate.setTime(expdate.getTime() 604800000); document.cookiecookieName";expires"expdate.toGMTString()";path /;domain.52z.com"; }//用于产生随机轮转广告 i 随机个…

SQL中合并多行记录的方法总汇

SQL中合并多行记录的方法总汇——前几天还在抱怨:sql只有sum(数值),不能sum(字符串)——如果不是分组统计,用select values values , value也是可以的——但是如果是分组sum(字符串),肯定不行了!——下面是用函数实…

Python中文编码判别及转换

为什么80%的码农都做不了架构师?>>> 养成使用utf8格式的习惯,但是不能保证所有的代码都是utf8格式,所以这里提供三个函数 getCoding tran2UTF8 tran2GBK ,分别是查看编码格式,转换为utf8,gbk格…

计算机二级中制作流程图的视频教程,流程图怎么做?1分钟教会你流程图制作方法...

流程是指在特定情景下用一系列逻辑满足特定用户需求的一种总结,借助流程图不仅可以梳理产品需求背后的逻辑和流程,还可以将新的想法和概念借助流程图这个载体分享出来,让整个项目参与者更好的认知产品设计的思路和逻辑。为了让职场的你更好的…

Source Generators实现简版AutoMapper

问题在业务开发中,我们常常需要将一个对象映射成另一个对象。例如将领域实体(UserEntity)映射成暴露给服务外部使用的数据传输对象(UserDto)。而AutoMapper则是目前主流的解决方案,实现类似如下代码:var configuration new MapperConfigurat…

15岁大学毕业,一生800多篇专著论文,双眼失明却凭一条公式称霸数学界

全世界只有3.14 %的人关注了青少年数学之旅从文明之火初燃的那一刻起数学就与之为伴从万年前“数”的产生到现代科技的迅猛发展数学不仅是窥探宇宙万物的入口也是最高智慧的结晶在漫漫的人类历史长河中各个伟大的数学家犹如布满“数学星空”中的星群他们追求最高的精确最合理的…

SEO | 重新认识一下Meta标签

很多人忽视了HTML标签META的强大功效&#xff0c;一个好的META标签设计可以大大提高你的个人网站被搜索到的可能性&#xff0c;有兴趣吗&#xff0c;谁我来重新认识一下META标签吧&#xff01; META标签是HTML语言HEAD区的一个辅助性标签&#xff0c;它位于HTML文档头部的<H…

不知道为什么IList.Contains()总是返回FALSE

需要override bool Equals(object obj) 转载于:https://www.cnblogs.com/shiningrise/archive/2009/04/16/1436845.html

Java程序员应该知道的10个Eclipse调试技巧

为什么80%的码农都做不了架构师&#xff1f;>>> Eclipse是众多Java程序员实用的开发工具&#xff0c;其中开发技巧也是繁多&#xff0c;但作为优秀的Java程序员&#xff0c;需要掌握最起码的调试技巧。 1 条件断点 2 异常断点 3 监视点 4 评估/检查 5 修改变量值 6…