css outline实践研究
2024-08-27 06:32:47
outline具有和border很相似的属性,但多少又有些区别,就是因为这些区别才让它闪闪发光,先目睹一下。
<style>
div{
width:100px;
height:100px;
background-color:red;
outline:10px solid #ccc;
}
</style>
<div></div>
好像和“border”没啥区别,那么看下面这张图
它的宽和高还是100px,并没有增加边框的宽度。
也就是说:outline
不占据布局空间,不会影响元素的尺寸,如果是这样的话,那可是可以解决很多问题啊,比如一个图片默认没有边框,hover的时候有一个1px的边框,那么如果不做处理盒子会抖动一下,解决这个问题可能就是默认给一个白色的边框或者给个padding,但是有了outline
就好办了,直接写就好了。
来研究一下它是不是真的不据布局空间。
它把下面的文字盖住了,但并没有改变元素的布局方式,这足够说明它确实是不占位置的。
outline
还有一个强大的属性叫outline-offset
可以设置边框的偏移量。
<style>
div{
margin:100px;
width:100px;
outline:1px solid red;
outline-offset:10px;
}
</style>
<div>追梦子</div>
值也可以是负的。
利用outline
制作炫酷效果
代码如下:
<style>
div{
margin:100px;
display:inline-block;
position:relative;
}
div::after{
content:'';
position:absolute;
left:-50px;
top:-100px;
width:100%;
height:100%;
outline:0px solid #fff;
outline-offset:15px;
transition:all .5s;
}
div:hover::after{
left:0px;
top:0px;
outline:1px solid currentColor;
outline-offset:3px;
}
</style>
<div>追梦子</div>
可以同时设置“border”和“outline”
<style>
div{
margin:100px;
width:100px;
border:1px solid red;
outline:1px solid red;
outline-offset:10px;
}
</style>
<div>追梦子</div>
不过值得注意的是,outline不会继承border-radius。
outline
结合offset
制作十字架
<style>
div{
margin: 0 auto;
width: 100px;
height: 100px;
background-color: red;
outline: 34px dotted #fff;
outline-offset: -33px;
}
</style>
<div></div>
<style>
div{
margin: 0 auto;
width: 100px;
height: 100px;
background-color: red;
position:relative;
}
div::after{
content:'';
width:100%;
height:100%;
position:absolute;
left:0;
top:0;
outline: 31px outset #fff;
outline-offset: -80px;
}
</style>
<div></div>
最新文章
- [LeetCode] Closest Binary Search Tree Value II 最近的二分搜索树的值之二
- Windows 保存BMP图片
- 【Android】键盘的展开和收起
- IOS学习笔记之 Socket 编程
- 2015安徽省赛 B.求和
- valueOf跟toString区别
- Android studio gradle 打包 那些事
- 常见sql语句及复杂sql语句记录
- 开始使用Logstash
- Qt Quick鼠标事件处理、键盘、计时器
- PHP从数据库获取的下拉树
- C++“窗体”程序设计启蒙
- 安卓开发之mqtt协议
- js面向对象学习
- phoenix API服务发布
- Java笔记(八)TreeMap &; TreeSet &; LinkedHashMap
- 基于CSS3动态背景登录框代码
- 查询某个SPID,session_id对应的执行sql.
- 【Ray Tracing in One Weekend 超详解】 光线追踪1-10
- Hive基础之Hive环境搭建
热门文章
- 20171126--fragment的小项目
- Java理论学时第二节。课后作业。
- SSM_CRUD新手练习(3)创建数据库
- 【MySQL】死锁问题分析
- Android FragmentActivity 嵌套 Fragment 调用startActivityForResult返回的requestCode错误
- Windows 95 输入法编辑器
- Windows 7/Vista下安装Oracle Developer Suit遇到的几个问题
- 1.Django入门
- hdu 1226 超级密码
- [ASE][Daily Scrum]11.12