详解三种CSS3模糊背景效果(代码实例)


本文摘自PHP中文网,作者青灯夜游,侵删。

本篇文章给大家介绍一下CSS3实现模糊背景的三种效果。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

不开头了,直接进入主题。

普通背景模糊效果如下:

这里写图片描述

使用属性:

1

filter:(2px)

####普通背景模糊

为了美观不能使背景前的文字模糊,而filter属性会使这整个p的后代并且还会出现白边。也就是说无法达到这个效果。怎么办呢?我们可以使用伪元素,这样我们也顺便解决了白边的问题。

实现思路:

在父容器中设置背景,并且使用相对定位,方便伪元素重叠。而在:after中只需要继承背景,并且设置模糊,绝对定位覆盖父元素即可。这样父容器中的子元素便可不受模糊度影响。因为伪元素的模糊度不能被父元素的子代继承。

说了这么多,来点代码提提神。

简单的html布局:

1

2

3

<div class="bg">

   <div class="drag">like window</div>

</div>

css:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

/*背景模糊*/

.bg{

    width:100%;

    height:100%;

    position: relative;

    background: url("../image/banner/banner.jpg") no-repeat fixed;

    padding:1px;

    box-sizing:border-box;

    z-index:1;

}

.bg:after{

    content: "";

    width:100%;

    height:100%;

    position: absolute;

    left:0;

    top:0;

    background: inherit;

    filter: blur(2px);

    z-index: 2;

}

.drag{

    position: absolute;

    left:50%;

    top:50%;

    transform: translate(-50%,-50%);

    width:200px;

    height:200px;

    text-align: center;

 

    z-index:11;

}

当然,看了上面的代码就能发现父容器下面的子代元素也是要使用绝对定位的,但是这个不会影响到后面的布局的,所以请放心使用(有问题可以找博主麻烦~)。要注意的地方是要使用z-index确定层级关系,必须确保子代元素(也就是这里的drag)是在最上层的。不然子代元素的文字是不会出现的。

上面的代码还有一个保证p居中的方法,细心的同学应该已经注意到了吧!不使用flex布局的情况下这样居中应该是比较简单的方法了。

那么这样写代码表现出来的效果是怎么样的呢?

这里写图片描述

####背景局部模糊

相比较上一个效果而言,背景局部模糊就比较简单了。这时父元素根本就不用设置伪元素为模糊了。直接类比上面的代码把子元素模糊掉,但是子元素的后代可能不能模糊了(这点要注意,解决办法就是上一个效果的描述那样)。

HTML布局稍微变了一下:

1

2

3

4

5

<div class="bg">

   <div class="drag">

        <div>like window</div>

   </div>

</div>

css代码如下:(大家注意对比)

阅读剩余部分

相关阅读 >>

css相对定位什么意思

css text-decoration属性怎么用

css怎么去掉div间距

css如何取消链接下划线

css中权重是什么意思

css超链接字体颜色如何改变

css如何实现幻灯片效果

css如何修改滚动条箭头样式

css怎么同时插两张背景图片

如何使用css对td中input的宽度设置

更多相关阅读请进入《css》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...