- vw/vh 方案
元素的宽高使用 vw/vh 长度单位,与设备视口宽高关联
缺点:兼容性有问题
- REM 方案
一切单位以设备宽度为准
使用 JS 把页面宽度转化为根元素的 font-size,然后再用与根元素 font-size 相关联的 rem 单位定义元素宽高,这样就等于使用了 rem 间接与页面宽度产生联系,确定了比例,从而实现等比缩放。
代码演示:
这样的话,当我们需要在屏幕宽度为 720px 的设备上显示一个宽为 50% 高为 25% 的元素时,我们就可以给这个元素添加样式:
.ele{
width:5rem; /* 原尺寸360px/根元素font-size72px */
height:2.5rem; /* 原尺寸180px/根元素font-size72px */
}
由于换算 px 和 rem 太麻烦,所以可以使用 Scss 函数对 px 单位进行自动换算。
- scss 安装与使用
npm config set registry https://registry.npm.taobao.org/
touch ~/.bashrc
echo ‘export SASS_BINARY_SITE=“https://npm.taobao.org/mirrors/node-sass”’ >> ~/.bashrc
source ~/.bashrc
npm i -g node-sass
mkdir ~/Desktop/scss-demo
cd ~/Desktop/scss-demo
mkdir scss css
touch scss/style.scss
start scss/style.scss
node-sass -wr scss -o css
编辑 scss 文件就会自动得到 css 文件
- px2rem
在 scss 文件里添加:
@function px( $px ){
@return p x / px/ px/designWidth*10 + rem;
}
$designWidth : 640; // 640 是设计稿的宽度,你要根据设计稿的宽度填写。
// $designWidth : $(window).width() css获取屏幕宽度
.child{
width: px(320);
height: px(160);
margin: px(40) px(40);
border: 1px solid red;
float: left;
font-size: 1.2em;
}
即可实现 px 自动变 rem
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!