html css部分背景模糊效果,CSS3实现模糊背景的三种效果示例

本文介绍了如何使用CSS3实现背景模糊的三种不同效果:普通背景模糊、背景局部模糊和背景局部清晰。通过使用伪元素、z-index和filter属性,可以巧妙地避免文字模糊并实现背景的特定区域模糊。详细代码示例展示了如何通过继承背景和调整定位来实现这些效果。同时,文章提醒注意使用z-index确保元素层级关系,并提供了不使用flex布局的居中方法。
摘要由CSDN通过智能技术生成

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

普通背景模糊效果如下:

37da2af0279144837d7b967c7c49e33f.png

使用属性:

filter:(2px)

普通背景模糊

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

实现思路:

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

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

简单的html布局:

like window

css:

/*背景模糊*/

.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)是在最上层的。不然子代元素的文字是不会出现的。

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

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

bfb791a942b67572d53fe2fa07de570b.png

背景局部模糊

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

HTML布局稍微变了一下:

like window

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

/*背景局部模糊*/

.bg{

width:100%;

height:100%;

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

padding:1px;

box-sizing:border-box;

z-index:1;

}

.drag{

margin:100px auto;

width:200px;

height:200px;

background: inherit;

position: relative;

}

.drag >div{

width:100%;

height: 100%;

text-align: center;

line-height:200px;

position: absolute;

left:0;

top:0;

z-index: 11;

}

.drag:after{

content: "";

width:100%;

height:100%;

position: absolute;

left:0;

top:0;

background: inherit;

filter: blur(15px);/*为了模糊更明显,调高模糊度*/

z-index: 2;

}

效果如下:

e95d07bcbca13549b4b9d600566967b9.png

背景局部清晰

背景局部清晰这个效果说简单也不简单,说难也不难。关键还是要应用好background:inherit属性。这里可不能使用transform让它垂直居中了,大家还是选择flex布局吧。如果这里再使用transform属性的话会让背景也偏移的。这样就没有局部清晰的效果了。

html布局不变,

注意看css的变化:

/*背景局部清晰*/

.bg{

width:100%;

height:100%;

position: relative;

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

padding:1px;

box-sizing:border-box;

}

.bg:after{

content: "";

width:100%;

height:100%;

position: absolute;

left:0;

top:0;

background: inherit;

filter: blur(3px);

z-index: 1;

}

.drag{

position: absolute;

left:40%;

top:30%;

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

width:200px;

height:200px;

text-align: center;

background: inherit;

z-index:11;

box-shadow: 0 0 10px 6px rgba(0,0,0,.5);

}

效果展示:

65ed29797e2d5e34be1b23846aa188ec.png

到此这篇关于CSS3实现模糊背景的三种效果示例的文章就介绍到这了,更多相关CSS3模糊背景内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值