博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSS3之------box-shadow属性使用方法(1),即单边阴影效果设置
阅读量:6681 次
发布时间:2019-06-25

本文共 1623 字,大约阅读时间需要 5 分钟。

3.5.2 box-shadow属性使用方法(1)

@原文url:http://book.51cto.com/art/201407/444460.htm

和PSD软件制作图片相比,box-shadow修改元素的阴影效果要方便得多,因为box-shadow可以修改六个参数,得到不同的效果。下面结合一些简单的案例来对box-shadow属性进行演示说明。

1.单边阴影效果

定义元素的单边阴影效果和调协border的单边边框颜色是相似的,例如:

  1. <html lang="en-US"
  2. <head
  3.   <meta charset="UTF-8"
  4.   <title>box-shadow设置单边阴影效果title
  5.   <style type="text/css"
  6.     .box-shadow {  
  7.       width: 200px;  
  8.       height: 100px;  
  9.       border-radius: 5px;  
  10.       border: 1px solid #ccc;  
  11.       margin: 20px;  
  12.     }  
  13.     .top {  
  14.       box-shadow: 0 -2px 0 red;  
  15.     }  
  16.     .right {  
  17.       box-shadow: 2px 0 0 green;  
  18.     }  
  19.     .bottom {  
  20.       box-shadow: 0 2px 0 blue;  
  21.     }  
  22.     .left {  
  23.       box-shadow: -2px 0 0 orange;  
  24.     }  
  25.   style
  26. head
  27. <body
  28.   <div class="box-shadow top">div
  29.   <div class="box-shadow right">div
  30.   <div class="box-shadow bottom">div
  31.   <div class="box-shadow left">div
  32. body
  33. html

效果如图3-38所示。

这个案例中,使用box-shadow给元素设置了顶边、右边、底边和左边的单边阴影效果。主要通过box-shadow的水平和垂直阴影的偏移量 来实现,其中x-offset为正值时,生成右边阴影,反之为负值时,生成左边阴影;y-offset为正值时,生成底部阴影,反之为负值时生成顶部阴 影。此例中是一个单边实影投影效果(阴影模糊半径为0),但是如果阴影的模糊半径不是0,上面的方法还能不能实现单边阴影效果呢?不急着来回答,在上面的 实例中添加一个模糊半径,例如:

  1. .top {  
  2.       box-shadow: 0 -2px 5px red;  
  3.     }  
  4.     .right {  
  5.       box-shadow: 2px 0 5px green;  
  6.     }  
  7.     .bottom {  
  8.       box-shadow: 0 2px 5px blue;  
  9.     }  
  10.     .left {  
  11.       box-shadow: -2px 0 5px orange;  
  12.     } 

图3-39说明,这个效果并不是理想的单边阴影效果,当box-shadow添加了5px阴影模糊半径后,阴影不再是实影投影,阴影清晰度向外扩散,更具阴影的效果。但造成了另一个问题,给元素其他三个边加上淡淡的阴影效果,可这并不是设计需要的效果。

那究竟要怎么做呢?此时,box-shadow属性中的阴影扩展半径(spread-radius)会是一个很关键的属性,要实现单边阴影效果,必须配上这个属性(除单边实影之外)。

  1. .top {  
  2.       box-shadow: 0 -4px 5px -3px red;  
  3.     }  
  4.     .right {  
  5.       box-shadow: 4px 0 5px -3px green;  
  6.     }  
  7.     .bottom {  
  8.       box-shadow: 0 4px 5px -3px blue;  
  9.     }  
  10.     .left {  
  11.       box-shadow: -4px 0 5px -3px orange;  
  12.     } 

上面的代码调整了阴影的位移量,新增了box-shadow的扩展半径,

转载于:https://www.cnblogs.com/ysdemo/p/9812873.html

你可能感兴趣的文章
Logback中文文档(三):配置
查看>>
【java】【多线程】等待开启的多个线程都执行完成,再做事情,怎么实现
查看>>
java 判断String字符串是不是json数据
查看>>
psql: FATAL: role “postgres” does not exist
查看>>
新版剑指offer14 剪绳子
查看>>
Feign 请求拦截器和日志
查看>>
WPF内实现与串口发送数据和接收数据
查看>>
Ideal test 不执行main方法了
查看>>
kbengine_js_plugins
查看>>
ElasticSearch的各种服务的URL
查看>>
工厂模式之数据工厂
查看>>
IBM Java多线程 - 1. 线程基础
查看>>
关系数据库的末日是否已经来临(转载)
查看>>
Myeclipse中导入jar包的方法
查看>>
topcoder srm 715 div1 -23
查看>>
梯度下降(Gradient Descent)小结
查看>>
一起谈.NET技术,使用User Control做HTML生成
查看>>
谷歌启动搜索引擎新功能 网页Flash内容即时预览
查看>>
专访梭子鱼:以“立体交付”保障Web应用安全
查看>>
微软SQL Server 2012新特性Silverlight报表客户端 - Power View
查看>>