当前位置: 首页 > news >正文

Safari 中 filter: blur() 高斯模糊引发的性能问题及解决方案

目录

    • 引言
      • 问题背景:filter: blur() 引发的问题
      • 产生问题的原因分析
      • 解决方案:开启硬件加速
      • 实际应用示例
      • 性能优化建议
      • 常见的调试工具与分析方法

引言

在前端开发中,CSS滤镜(如filter: blur())的广泛使用为页面带来了各种精美的视觉效果。然而,在特定的浏览器中,比如Safari,我们经常会发现一些让人头痛的性能问题。
特别是在使用filter: blur()高斯模糊效果时,Safari会出现奇怪的小方块和页面卡顿等现象,严重影响用户体验。这些问题大部分与浏览器的渲染机制以及硬件加速的使用有关。

问题背景:filter: blur() 引发的问题

CSS filter属性提供了一系列丰富的滤镜效果,例如模糊、亮度、对比度等。其中,blur()高斯模糊可以为页面中的元素带来柔和的视觉效果,让用户感觉到元素的模糊或背景虚化的渐变变化,广泛应用于模态框的背景、图片效果等。

然而,当我们在Safari中使用filter: blur(),并将模糊程度设得很高(例如blur(200px)),会产生以下问题:

  1. 奇怪的小方块:在某些设备或某些情况下,使用模糊效果后,背景或页面元素上可能会出现像素化的小方块,视觉上非常不美观。

  2. 卡顿和性能问题:尤其是在渲染复杂内容或有较多DOM节点的情况下,页面的滚动和动画会变得非常卡顿,用户体验极差。

  3. 这些问题主要集中在Safari浏览器中,并且在移动端Safari上尤为明显。

在这里插入图片描述

产生问题的原因分析

在讨论解决方案之前,我们先来了解这些性能问题产生的原因。通常来说,性能问题和渲染效果问题多与以下因素有关:

  1. Safari 渲染机制

Safari使用的WebKit引擎在处理某些CSS滤镜(尤其是blur高斯模糊)时,可能无法高效地处理像素的重计算。filter: blur()需要对每个像素进行复杂的计算,尤其在高模糊值的情况下,每次页面滚动或重绘时,Safari都必须重新计算这些像素,从而导致页面渲染性能下降,甚至出现卡顿。

  1. 硬件加速的缺失

硬件加速能够将渲染任务交由GPU完成,从而减轻CPU的压力。如果页面渲染未启用硬件加速,所有的CSS滤镜效果(如模糊)都将由CPU处理,这对于需要大量计算的高斯模糊来说,负担非常大。而Safari默认情况下,某些滤镜操作并未启用硬件加速,从而导致了性能瓶颈。

  1. 高斯模糊的计算复杂度

filter: blur() 的实现需要在每次渲染时重新计算周围像素的平均值。当模糊值很高时,这种计算需要涉及到大量的像素点。对于普通的设备,尤其是在移动端Safari上,计算复杂度过高会导致明显的卡顿和掉帧现象。

解决方案:开启硬件加速

既然问题主要在于Safari对filter: blur()的渲染效率低下,我们可以通过开启硬件加速来有效解决这一问题。硬件加速的基本思路是将渲染工作交由GPU完成,而不是由CPU独自承担。GPU在处理图像计算方面具有明显的优势,这也是我们解决问题的关键。

  1. 如何开启硬件加速

我们可以通过CSS中的transform属性开启硬件加速。一个最常见的做法是使用transform: translate3d(0, 0, 0)来触发硬件加速。具体实现如下:

.example {filter: blur(200px);transform: translate3d(0, 0, 0); /* 触发硬件加速 */
}

在这个例子中,我们为模糊效果元素添加了transform: translate3d(0, 0, 0),这将告诉浏览器该元素需要开启硬件加速,从而由GPU来进行处理。这种方法对解决Safari上的卡顿和小方块问题有着显著效果。

  1. 其他触发硬件加速的方法

除了使用transform: translate3d(0, 0, 0),还有一些其他方法可以触发硬件加速:

使用will-change属性:

.example {filter: blur(200px);will-change: transform, filter;
}

will-change属性告诉浏览器,元素的某些属性即将发生变化,因此需要对该元素进行优化。这能够使浏览器为即将发生的变化做好准备,从而提升渲染性能。

使用transform: scale(1):
这种方法也可以用来触发硬件加速,但与translate3d相比,效果可能略有不同。

实际应用示例

为了更直观地展示硬件加速的效果,以下是一个包含模糊效果的示例代码。这个示例将演示如何通过硬件加速优化Safari中的模糊效果。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Safari 模糊性能优化</title><style>.blurred-background {width: 100%;height: 300px;background: url('background.jpg') no-repeat center center;background-size: cover;filter: blur(200px);transform: translate3d(0, 0, 0); /* 触发硬件加速 */}</style>
</head>
<body><div class="blurred-background"></div>
</body>
</html>

在这个例子中,我们有一个模糊背景的div,通过应用filter: blur(200px)来实现模糊效果,同时使用transform: translate3d(0, 0, 0)来触发硬件加速,从而避免了Safari中的性能问题。

性能优化建议

除了开启硬件加速,我们还可以采取其他一些措施来进一步优化页面中的模糊效果,尤其是在需要处理大量元素或高频率重绘的场景中:

  1. 降低模糊半径

对于大多数情况来说,较高的模糊半径会导致性能瓶颈。如果blur()的值太大,Safari和其他浏览器在渲染时都会遇到困难。尽量减少模糊值可以显著提升性能。

  1. 限制模糊区域

尽量避免对整个页面或大面积的元素应用模糊效果。将模糊效果应用于小面积的局部区域,可以有效减少浏览器的重绘开销。

  1. 结合动画优化

当模糊效果与动画一起使用时,必须谨慎处理。可以通过减少动画的频率、使用CSS3动画而不是JavaScript动画来提高性能。尽量让GPU处理动画和滤镜效果,避免在复杂动画下引发额外的CPU开销。

  1. 使用适当的分层

在现代浏览器中,创建新的图层可以有效提高页面渲染性能。通过will-change或transform属性将需要模糊的元素置于一个独立的图层中,这样可以减少页面重绘时对其他元素的影响。

常见的调试工具与分析方法

当我们遇到Safari性能问题时,可以使用一些调试工具来分析页面渲染的瓶颈,并找到问题所在:

  1. Safari 开发者工具:Safari 自带的开发者工具可以用来检查页面的性能问题。在Timelines标签中,可以查看页面的渲染时间线,分析出具体哪些元素或样式导致了卡顿。

  2. Chrome DevTools 的远程调试:通过连接iPhone设备,我们可以使用Chrome DevTools对移动端Safari进行远程调试。这样可以更加方便地检测和修复移动端的性能问题。

  3. 使用 Lighthouse:虽然主要是用于Chrome的插件,但Lighthouse也可以用于分析页面的性能,给出具体的优化建议。

相关文章:

Safari 中 filter: blur() 高斯模糊引发的性能问题及解决方案

目录 引言问题背景&#xff1a;filter: blur() 引发的问题产生问题的原因分析解决方案&#xff1a;开启硬件加速实际应用示例性能优化建议常见的调试工具与分析方法 引言 在前端开发中&#xff0c;CSS滤镜&#xff08;如filter: blur()&#xff09;的广泛使用为页面带来了各种…...

浏览器实时更新esp32-c3 Supermini http server 数据

一利用此程序的思路就可以用浏览器显示esp32 采集的各种传感器的数据&#xff0c;也可以去控制各种传感器。省去编写针对各系统的app. 图片 1.浏览器每隔1秒更新一次数据 2.现在更新的是开机数据&#xff0c;运用此程序&#xff0c;可以实时显示各种传感器的实时数据 3.es…...

【亚马逊云】基于 Amazon EKS 搭建开源向量数据库 Milvus

文章目录 一、先决条件1.1 安装AWS CLI ✅1.2 安装 EKS 相关工具✅1.3 创建 Amazon S3 存储桶✅1.4 创建 Amazon MSK 实例✅ 二、创建EKS集群三、创建 ebs-sc StorageClass四、安装 AWS Load Balancer Controller五、部署 Milvus 数据库5.1 添加 Milvus Helm 仓库5.2 配置 S3 作…...

pytorch安装GPU版本,指定设备

安装了GPU版本的pytorch的时候&#xff0c;想要使用CPU&#xff0c;怎么操作呢&#xff1f; 设置环境变量&#xff1a; set TF_FORCE_GPU_ALLOW_GROWTHfalse set CUDA_VISIBLE_DEVICES如果想要使用固定序号的GUP设备&#xff0c;则指定ID set CUDA_VISIBLE_DEVICES0 # 使用第…...

草地杂草数据集野外草地数据集田间野草数据集YOLO格式VOC格式目标检测计算机视觉数据集

一、数据集概述 数据集名称&#xff1a;杂草图像数据集 数据集是一个包含野草种类的集合&#xff0c;其中每种野草都有详细的特征描述和标记。这些数据可以包括野草的图片、生长习性、叶片形状、颜色等特征。 1.1可能应用的领域 农业领域: 农业专家和农民可以利用这一数据集来…...

顺序表排序相关算法题|负数移到正数前面|奇数移到偶数前面|小于x的数移到大于x的数前面|快排思想(C)

负数移到正数前面 已知顺序表 ( a 1 , … , a n ) (a_{1},\dots,a_{n}) (a1​,…,an​)&#xff0c;每个元素都是整数&#xff0c;把所有值为负数的元素移到全部正数值元素前边 算法思想 快排的前后指针版本 排序|冒泡排序|快速排序|霍尔版本|挖坑版本|前后指针版本|非递归版…...

【小白学机器学习20】单变量分析 / 0因子分析 (只分析1个变量本身的数据)

目录 1 什么是单变量分析&#xff08;就是只分析数据本身&#xff09; 1.1 不同的名字 1.2 《戏说统计》这本书里很多概念和一般的书不一样 1.3 具体来说&#xff0c;各种概率分布都属于单变量分析 2 一维的数据分析的几个层次 2.1 数据分析的层次 2.2 一维的数据为什么…...

[软件工程]—桥接(Brige)模式与伪码推导

桥接&#xff08;Brige&#xff09;模式与伪码推导 1.基本概念 1.1 动机 由于某些类型的固有的实现逻辑&#xff0c;使它们具有两个变化的维度&#xff0c;乃至多个维度的变化。如何应对这种“多维度的变化”&#xff1f;如何利用面向对象技术是的类型可以轻松的沿着两个乃至…...

TensorFlow面试整理-TensorFlow 结构与组件

TensorFlow 的结构和组件是其功能强大、灵活性高的重要原因。掌握这些结构和组件有助于更好地理解和使用 TensorFlow 构建、训练和部署模型。以下是 TensorFlow 关键的结构与组件介绍: 1. Tensor(张量) 定义:张量是 TensorFlow 中的数据载体,类似于多维数组或矩阵。张量的…...

linux下gpio模拟spi三线时序

目录 前言一、配置内容二、驱动代码实现三、总结 前言 本笔记总结linux下使用gpio模拟spi时序的方法&#xff0c;基于arm64架构的一个SOC&#xff0c;linux内核版本为linux5.10.xxx&#xff0c;以驱动三线spi(时钟线sclk&#xff0c;片选cs&#xff0c;sdata数据读和写使用同一…...

makesense导出的压缩包是空的

md ,那些教程感觉都不是人写的&#xff0c;没说要在右边选标签&#xff0c;我本来就是一个标签&#xff0c;我以为他会自动识别打标&#xff0c;结果死活导出来空包 密码要在右边选标签&#xff0c;...

Spring Boot框架下的中小企业设备维护系统

5系统详细实现 5.1 用户信息管理 中小企业设备管理系统的系统管理员可以对用户信息添加修改删除以及查询操作。具体界面的展示如图5.1所示。 图5.1 用户信息管理界面 5.2 员工信息管理 管理员可以对员工信息进行添加修改删除操作。具体界面如图5.2所示。 图5.2 员工信息界面…...

处理文件上传和进度条的显示(进度条随文件上传进度值变化)

成品效果图&#xff1a; 解决问题&#xff1a;上传文件过大时&#xff0c;等待时间过长&#xff0c;但是进度条却不会动&#xff0c;只会在上传完成之后才会显示上传完成 上传文件的upload.component.html <nz-modal [(nzVisible)]"isVisible" [nzTitle]"文…...

【套题】大沥2019年真题——第5题

05.魔术数组 题目描述 一个 N 行 N 列的二维数组&#xff0c;如果它满足如下的特性&#xff0c;则成为“魔术数组”&#xff1a; 1、从二维数组任意选出 N 个整数。 2、选出的 N 个整数都是在不同的行且在不同的列。 3、在满足上述两个条件下&#xff0c;任意选出来的 N 个整…...

上传Gitee仓库流程图

推荐一个流程图工具 登录 | ProcessOnProcessOn是一个在线协作绘图平台&#xff0c;为用户提供强大、易用的作图工具&#xff01;支持在线创作流程图、思维导图、组织结构图、网络拓扑图、BPMN、UML图、UI界面原型设计、iOS界面原型设计等。同时依托于互联网实现了人与人之间的…...

二叉树相关OJ题 — 第一弹

目录 1. 检验两棵树是否相同 ​编辑 1. 题目解析 2. 解题步骤 2.判断一棵大树中是否包含有和一棵小树具有相同结构和节点值的子树 1. 题目解析 2. 解题步骤 3. 翻转二叉树 1. 题目解析 2.解题步骤 4. 判断一颗二叉树是否是平衡二叉树 1. 题目解析 2. 解题步骤…...

【学习笔记】RFID

RFID 1、 概述 1.1、RFID 介绍 1.2、RFID 发展史 1.3、RFID 系统的构造 1.3.1、阅读器 Reader 和 天线 Antenna 1.3.3、电子标签 tag 1.4、电子标签按吐字率分类 1.5、电子标签按能量供应的方式划分 1.6、RFID 工作流程 …...

自动化部署-01-jenkins安装

文章目录 前言一、下载安装二、启动三、问题3.1 jdk版本问题3.2 端口冲突3.3 库文件加载问题3.4 系统字体配置问题 四、再次启动五、配置jenkins5.1 解锁5.2 安装插件5.3 创建管理员用户5.4 实例配置5.5 开始使用5.6 完成 总结 前言 spingcloud微服务等每次部署到服务器上&…...

AI工具大爆发,建议每个都使用收藏

2024年被誉为AI应用元年&#xff0c;这一年人们普遍意识到&#xff0c;未来占据主导地位的将是基于大模型的应用程序&#xff0c;而不仅仅是大模型本身。因此&#xff0c;在这一趋势的推动下&#xff0c;各式各样的AI应用如雨后春笋般涌现出来。 今天就聊聊这些好用的AI工具&a…...

Mybatis之参数处理

在MyBatis中&#xff0c;参数处理是非常关键的部分&#xff0c;它负责将传入的参数正确映射到SQL语句中 单个简单类型参数 简单类型对于mybatis来说都是可以自动类型识别的&#xff1a; 也就是说对于mybatis来说&#xff0c;它是可以自动推断出ps.setXxxx()方法的。ps.setSt…...

windows内核探索--打印windows的GDT表(全局描述符表)

x86 #include <windows.h> #include<stdio.h> #include "x86struct.h" void PrintSegmentDescriptor(ULONG64* sd, WORD Count); SegmentSelector GetSegmentSelector(USHORT Selector); int main() {printf("0环cs段寄存器 ");GetSegmentSel…...

【ChatGPT】让ChatGPT帮助进行头脑风暴与创意生成

让ChatGPT帮助进行头脑风暴与创意生成 在日常工作和生活中&#xff0c;创意和头脑风暴是解决问题、创新和推动项目的关键步骤。ChatGPT&#xff0c;作为一个强大的语言模型&#xff0c;不仅可以提供信息和答案&#xff0c;还可以成为强大的头脑风暴工具&#xff0c;帮助用户快…...

大数据处理随堂测试

HDFS MapReduce HBase Spark...

2024最新pycharm安装教程及基本使用(超详细,新手小白必看)

文章目录 前言一、官网下载二、安装步骤三、使用示范四、番外篇&#xff08;汉&#xff09;大纲 PythonPyCharm安装包领取方式戳‘这块里’ 前言 一、官网下载 1. 进入pycharm官网&#xff0c;点击下载 PyCharm: The Python IDE for data science and web development by J…...

三国杀钓鱼自动化

三国杀钓鱼脚本 前言 本来是想做必杀的&#xff0c;但是后来测试了大约400钓发现纯靠连点没有漏掉的鱼&#xff0c;所以必杀功能就舍弃了。 我pyinstaller打包后运行.exe居然黑屏了&#xff1f;&#xff1f;&#xff1f;可能是多进程报错处理没写好&#xff0c;反正还是用vsc…...

在pycharm中使用sqllite

在pycharm中使用sqllite sqllite 简介 SQLite 是一个开源的、轻量级的、关系型数据库管理系统&#xff08;RDBMS&#xff09;&#xff0c;它设计用于嵌入到应用程序中&#xff0c;并且可以在无需外部服务器进程的情况下运行。SQLite 提供了完整的 SQL 语言支持&#xff0c;允…...

Linux——文件操作

前言 1&#xff09;在Linux下面&#xff0c;一切皆文件&#xff0c;文件文件内容文件属性 2&#xff09;在访问文件是&#xff0c;都得先将文件打开&#xff0c;修改文件的本质其实还是通过执行代码的形式修改。 3&#xff09;文件是被进程打开的&#xff0c;一个进程可以打…...

数据结构 ——— 数组栈oj题:有效括号

目录 题目要求 代码实现 题目要求 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 每…...

Character AI被起诉!14岁青少年自杀,AI陪伴何去何从

终于&#xff0c;AI在青少年心理问题方面&#xff0c;被推上了风口浪尖。 最近&#xff0c;美国佛罗里达州&#xff0c;一名14岁男孩Sewell Setzer的父母控告Character AI公司&#xff0c;声称孩子沉迷该公司的AI聊天机器人&#xff0c;最后走上了自杀的道路。 跟AI聊天还能致…...

CSS3 动画相关属性实例大全(三)(columns、filter、flex、flex-basis 、flex-grow、flex-shrink属性)

CSS3 动画相关属性实例大全&#xff08;三) &#xff08;columns、filter、flex、flex-basis 、flex-grow、flex-shrink属性&#xff09; 本文目录&#xff1a; 一、columns属性&#xff08;设置元素的列宽和列数&#xff09; 二、filter属性&#xff08;调整图像、背景和边…...

四川 法治政府建设 网站/长沙网络推广小公司

北上广深等一线城市的人口日益增多&#xff0c;职场白领群体增加&#xff0c;而办公软件的使用&#xff0c;更是帮助白领们提高效率、企业节省运营成本的有效方式&#xff0c;而对于个人邮箱品牌的选择上&#xff0c;更是有种选优&#xff0c;TOM VIP邮箱凭借独特的优势&#x…...

做网站要商标吗/百度指数查询官网大数据

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请注明出处&#xff1a;https://twocups.cn/index.php/2020/02/05/18/ 有时我们需要对同一类型的对象进行多种不同方式的排序&#xff0c;而自然排序 Comparable 并不能实现。这里我们就需要重写比较器&#xff0c;可以…...

logo设计网站国外/哪家网络公司比较好

原文章&#xff1a;https://code.visualstudio.com/docs/cpp/config-mingw 1 安装Visual Studio Code 进入VS Code官方网站下载VS Code安装包在面板左侧找到扩展Ctrl Shift X 搜索Chinese并点击Install 根据右下角提示重启VS Code在扩展中搜索C/C并安装 2 安装Mingw-w64 …...

网站seo优化要怎么做/企业宣传软文

抖音web view默认的body是黑色的背景&#xff0c;写代码的时候要替换下用自己的颜色 body {background: #fff; }...

网站建设需要精通什么知识/苏州seo服务

如何制作gif图&#xff1f;如何上传你项目的动态效果图到你的csdn&#xff1f; 这只是笔者用的方法&#xff0c;有其他方法的欢迎分享。 一张或几张展示了你的项目的功能及效果的动态图放在博客文章开头会为你的文章润色不少。 相信很多写博客的伙伴都会遇到这样一个问题&…...

做外贸出口的网站/网站策划是干什么的

%86时出现报错 Error in invoking target agent nmhs of makefile 解决方案在makefile中添加链接libnnz11库的参数修改$ORACLE_HOME/sysman/lib/ins_emagent.mk&#xff0c;将$(MK_EMAGENT_NMECTL)修改为&#xff1a;$(MK_EMAGENT_NMECTL) -lnnz11建议修改前备份原始文件[ora…...