• CSS3实现多样的边框效果


    半透明边框

    实现效果:

    实现代码:

    <div>
    你能看到半透明的边框吗?
    </div>
    
    div {
    
    	/* 关键代码 */
    	border: 10px solid rgba(255,255,255,.5);
    	background: white;
    	background-clip: padding-box;
    	
    	/* 其它样式 */
    	max- 20em;
    	padding: 2em;
    	margin: 2em auto 0;
    	font: 100%/1.5 sans-serif;
    }
    

    实现要点:

    • 设置边框为半透明,这是还看不到半透明边框,因为默认情况下,背景会延伸到边框所在的区域下层,也就是背景是被边框的外沿框裁切掉。
    • 通过设置 background-clip: padding-box (初始值是 border-box) 让背景不要延伸到边框所在的区域下层,也就是让内边距的外沿来裁切背景。

    多重边框

    实现效果:

    实现代码:

    <div></div>
    
    /* box-shadow 实现方案 */
    div {
    
    	/* 关键代码 */
    	box-shadow: 0 0 0 10px #655,
                0 0 0 15px deeppink,
                0 2px 5px 15px rgba(0,0,0,.6);
    	
    	/* 其它样式 */
    	 100px;
    	height: 60px;
    	margin: 25px;
    	background: yellowgreen;
    }
    
    /* border/outline 实现方案 */
    div {
    
    	/* 关键代码 */
    	border: 10px solid #655;
    	outline: 5px solid deeppink;
    	
    	/* 其它样式 */
    	 100px;
    	height: 60px;
    	margin: 25px;
    	background: yellowgreen;
    }
    

    实现要点:

    • box-shadow 实现方案使用的是 box-shadow 的第四个参数(扩张半径)。一个正值的扩张半径加上两个为零的偏移量以及为零的模糊值,得到的“投影”其实就像一道实线边框。而借助 box-shadow 支持逗号分割语法,可创建任意数量的投影,因此我们就可实现多重边框效果。
    • border/outline 实现方案是使用 border 设置一层边框,再使用 outline 设置一层边框。这个方案可实现虚线边框,但它只能实现两层边框。

    边框内圆角

    实现效果:

    实现代码:

    <div>我有一个漂亮的内圆角</div>
    
    div {
    	outline: .6em solid #655;
    	box-shadow: 0 0 0 .4em #655; /* 关键代码 */
    	
    	max- 10em;
    	border-radius: .8em;
    	padding: 1em;
    	margin: 1em;
    	background: tan;
    	font: 100%/1.5 sans-serif;
    }
    

    实现要点:

    • outline 不会跟着元素的圆角走(因而显示出直角),但 box-shadow 确实会的,因此,将两者叠加到一起,box-shadow(其扩张值大概等于 border-radius 值的一半) 会刚好填补 outline 和容器圆角之间的空隙,因此可达到我们想要的效果。
  • 相关阅读:
    使用鼠标
    TCP编程函数和步骤
    ASP.NET MVC+EF框架+EasyUI实现
    线性表简介
    一个项目的简单开发流程——需求、数据库、编码
    图像处理网络资源
    OPENCV 中的图像旋转与缩放
    命令行下面使用MAKEFILE方式编译OPENCV程序
    OpenCV In Thanksgiving Day
    OpenCV 下面的图像亮度变换 Intensity transformation
  • 原文地址:https://www.cnblogs.com/laixiangran/p/8988090.html
Copyright © 2020-2023  润新知