html5中实现滤镜透明度混合和设置透明度滤镜,主要有两种常用方案,分别是使用CSS的filter属性操作DOM元素,以及使用canvas的globalAlpha属性和混合模式处理绘图内容,两种方案适用场景不同,操作逻辑也有区别。

一、使用CSS filter属性设置元素透明度滤镜
CSS的filter属性是html5新增的样式属性,支持直接为DOM元素添加多种滤镜效果,其中opacity函数可以直接调整元素的透明度,实现基础的透明度滤镜效果,这种方式操作简单,适合处理普通页面元素的透明度需求。
1. 基础opacity滤镜设置
直接在元素的style中添加filter: opacity(数值)即可,数值范围是0到1,0表示完全透明,1表示完全不透明,也可以通过百分比设置,0%到100%对应0到1的范围。
/* 设置div元素透明度为50% */
.transparent-div {
width: 200px;
height: 200px;
background-color: #ff0000;
/* 透明度滤镜,0.5表示半透明 */
filter: opacity(0.5);
/* 兼容旧版本浏览器可添加前缀 */
-webkit-filter: opacity(0.5);
}
2. 结合其他滤镜实现混合效果
filter属性支持同时添加多个滤镜函数,用空格分隔即可,比如可以结合blur滤镜实现带模糊效果的半透明元素,实现简单的混合视觉。
/* 同时添加模糊和透明度滤镜 */
.mixed-filter-div {
width: 200px;
height: 200px;
background-color: #00ff00;
/* 先模糊5像素,再设置60%透明度 */
filter: blur(5px) opacity(0.6);
}
二、使用canvas实现透明度混合滤镜
如果需要处理绘图内容的透明度混合,比如两张图片叠加时的透明度融合,使用canvas会更灵活,canvas提供了globalAlpha属性和globalCompositeOperation属性,分别控制全局透明度和混合模式。
1. 使用globalAlpha设置绘图透明度
globalAlpha属性用于设置后续绘制内容的基础透明度,取值范围同样是0到1,设置后所有后续的绘制操作都会应用这个透明度值,直到重新修改该属性。
// 获取canvas元素和上下文
const canvas = document.getElementById('myCanvas');
const ctx = canvas.getContext('2d');
// 设置全局透明度为0.7,后续绘制的内容都是70%不透明
ctx.globalAlpha = 0.7;
// 绘制红色矩形,会应用0.7的透明度
ctx.fillStyle = '#ff0000';
ctx.fillRect(50, 50, 150, 150);
// 绘制蓝色圆形,同样应用0.7的透明度
ctx.fillStyle = '#0000ff';
ctx.beginPath();
ctx.arc(150, 150, 60, 0, Math.PI * 2);
ctx.fill();
2. 使用混合模式实现透明度融合
globalCompositeOperation属性可以设置新绘制内容和已有内容的混合规则,结合globalAlpha可以实现更复杂的透明度混合效果,比如source-over是默认模式,新内容会覆盖在旧内容上方并应用透明度。
const canvas = document.getElementById('mixCanvas');
const ctx = canvas.getContext('2d');
// 先绘制一个不透明的黄色矩形作为底层
ctx.fillStyle = '#ffff00';
ctx.fillRect(30, 30, 200, 200);
// 设置透明度为0.5
ctx.globalAlpha = 0.5;
// 设置混合模式为source-over,新内容叠加在旧内容上方
ctx.globalCompositeOperation = 'source-over';
// 绘制半透明的蓝色矩形,会和黄色矩形混合显示
ctx.fillStyle = '#0000ff';
ctx.fillRect(100, 100, 200, 200);
两种方案的选择建议
如果是普通DOM元素的透明度滤镜需求,优先选择CSS filter方案,代码量少且性能更好;如果是canvas绘图、图片叠加、动态绘制特效等场景,选择canvas的globalAlpha和混合模式方案,可定制性更强。需要注意的是,CSS的filter属性在部分旧版本移动端浏览器可能存在兼容问题,如果需要兼容旧环境,建议提前测试或者选择canvas方案。
| 方案类型 | 适用场景 | 核心属性/方法 |
|---|---|---|
| CSS filter | 普通DOM元素透明度滤镜、简单滤镜组合 | filter: opacity() |
| canvas | 绘图内容透明度混合、动态特效、图片叠加 | globalAlpha、globalCompositeOperation |