沉沙
2018-06-12
来源 :
阅读 1542
评论 0
摘要:在移动端有时1px的边框会显得很粗不美观,淘宝、京东的触屏均是采用浅细的线条来显示在移动设备上。希望阅读本篇文章以后大家有所收获,帮助大家HTML5+CSS3从入门到精通 。
在移动端有时1px的边框会显得很粗不美观,淘宝、京东的触屏均是采用浅细的线条来显示在移动设备上。具体实现方法如下:
普通的1px黑色实线边框:
border: 1px solid #000;
半像素边框当然不是简单地把1px改为0.5px(会被解析成1px),border-width的值只能是自然数
类似的,outline, box-shadow等等也没有办法画出0.5px的细线
常规思路是不可行的,我们可以用伪元素 + 缩放巧妙地实现。
具体步骤如下:
设置目标元素作为定位参照
.thinner-border {
position: relative; /* 只要不是默认值static即可 */
}给目标元素添加一个伪元素before或者after,并设置绝对定位
.thinner-border:before {
content: '';
position: absolute;
}给伪元素添上1px的边框
border: 1px solid red;
设置伪元素的宽高为目标元素的2倍
width: 200%;height: 200%;
缩小0.5倍(变回目标元素的大小)
transform-origin: 0 0;transform: scale(0.5, 0.5);
把border包进来
box-sizing: border-box;
简言之就是先放大再缩回来,border-box是关键,否则边框不会一起缩放
具体实现
上面已经分步骤写得很清楚了,拼在一起就是完整实现:
.thinner-border {
position: relative;
}
.thinner-border:before {
content: '';
position: absolute;
width: 200%;
height: 200%;
border: 1px solid #000;
-webkit-transform-origin: 0 0;
-moz-transform-origin: 0 0;
-ms-transform-origin: 0 0;
-o-transform-origin: 0 0;
transform-origin: 0 0;
-webkit-transform: scale(0.5, 0.5);
-ms-transform: scale(0.5, 0.5);
-o-transform: scale(0.5, 0.5);
transform: scale(0.5, 0.5);
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}功能是给class值指定了thinner-border的block和inline-block元素添上半像素的边框,因为inline元素的width和height有一些限制,伪元素获取到的200%要比实际值小,边框的宽高也会比期望的小。
本文由职坐标整理并发布,了解更多内容,请关注职坐标WEB前端HTML5/CSS3频道!
喜欢 | 0
不喜欢 | 0
您输入的评论内容中包含违禁敏感词
我知道了

请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号