搜索
首页web前端css教程让我们使用SVG剪辑路径创建图像弹出效果

让我们使用SVG剪辑路径创建图像弹出效果

几周前,我偶然发现了Mikael Ainalem的这种很酷的弹出效果。它在CSS中展示了剪辑路径:path(),它在大多数现代浏览器中都得到了适当的支持。我想自己挖掘它,以更好地了解它的工作原理。但是在此过程中,我发现了剪辑路径的一些问题:path();并结束了在本文中找到我想与您一起浏览的另一种方法。

如果您尚未使用剪辑路径或不熟悉它,它基本上允许我们根据剪辑路径为元素指定显示区域,并隐藏落在夹子路径外的元素的部分。

剪辑路径的可能值包括圆,椭圆和多边形,将用例限制为这些特定形状。这是新的路径值所在的地方 - 它使我们能够使用更灵活的SVG路径来创建超出基本形状的各种剪辑路径。

让我们来了解有关剪辑路径的知识,并开始致力于悬停效果。使人的前景图像的基本思想似乎是从五颜六色的背景中弹出的,当元素悬停时大小的规模。一个重要的细节是前景图像动画(扩展和移动)如何独立于背景图像动画(仅扩展)。

这种效果看起来很酷,但是路径值存在一些问题。对于初学者来说,尽管我们提到支持通常是好的,但它不是很好,并且在撰写本文时徘徊了约82%的覆盖范围。因此,请记住,目前移动支持仅限于Chrome和Safari。

除了支持外,路径的更大,更奇怪的问题是,它目前仅适用于像素值,这意味着它没有响应。例如,假设我们放大了页面。马上,路径形状开始切断。

这严重限制了夹子路径的用例:path(),因为它只能在固定尺寸的元素上使用。多年来,响应式Web设计一直是广泛接受的标准,因此看到不遵循原则并专门使用像素单元的新CSS属性很奇怪。

我们要做的就是使用标准,广泛支持的CSS技术重新创建这种效果,以便它不仅有效,而且确实具有响应速度。

棘手的部分

我们希望任何溢出剪贴路径的东西只能在图像的顶部可见。我们不能使用标准CSS溢出属性,因为它会影响顶部和底部。

那么,除了溢出和剪辑路径外,我们还有什么选择?好吧,让我们在SVG本身中使用是一种SVG属性,它与新发行的和无反应的剪辑路径:路径不同。

SVG 元素

svg 和元素适应了SVG元素的坐标系,因此它们可以响应开箱即用。随着SVG元素的缩放,其坐标系也正在缩放,并根据涵盖广泛可能的用例的各种属性维持其比例。作为另外的好处,在SVG上使用CSS中使用夹式路径具有95%的浏览器支持,与夹子路径相比,它增加了13%。

让我们从设置我们的SVG元素开始。我使用Inkscape创建了基本的SVG标记和剪裁路径,只是为了使自己变得容易。完成此操作后,我通过添加自己的类属性来更新标记。

 <svg xmlns="“" http: viewbox="“">
  <defs>
    <clippath clippathunits="“" userpaceonuse>
      
    </clippath>
    <clippath clippathunits="“" userpaceonuse>
      
    </clippath>
  </defs>
  <g clip url transform="“" transfate>
    
    <image clip-path="“" url width="“" height="“" x="“" y="“" href="%E2%80%9C" ... transform="“" translate></image>
    
    
  </g>
</svg>

此标记可以很容易地用于其他背景图像和前景图像。我们只需要在图像元素内部的HREF属性中替换URL即可。

现在,我们可以在CSS中进行悬停动画。我们可以通过转换和过渡来度过难关,确保前景很好地集中,然后在悬停时进行缩放和移动事物。

 。图像 {
  变换:比例尺(0.9,0.9);
  过渡:变换0.2s易于启动;
}

.image__foreground {
  转化原始:50%50%;
  变换:translatey(4px)比例(1,1);
  过渡:变换0.2s易于启动;
}

图像:悬停{
  变换:比例尺(1,1);
}

.Image:Hover .Image__foreground {
  变换:translatey(-7px)比例(1.05,1.05);
}

这是上述HTML和CSS代码的结果。尝试调整屏幕大小并更改SVG元素的尺寸,以查看效果如何随屏幕尺寸缩放。

这看起来很棒!但是,我们还没有完成。我们仍然需要解决一些问题,因为我们已经将标记从HTML图像元素更改为SVG元素。

SEO和可访问性

内联SVG元素不会被搜索爬网索引。如果SVG元素是内容的重要组成部分,则您的页面SEO可能会受到打击,因为这些图像可能不会被拾取。

我们需要其他标记,该标记使用CSS隐藏的常规让我们使用SVG剪辑路径创建图像弹出效果元素。以这种方式声明的图像会被爬网机自动拾取,我们可以在图像站点地图中提供指向这些图像的链接,以确保爬网设法设法找到它们。我们正在使用加载=“懒惰”,允许浏览器决定是否应推迟加载图像。

我们将把两个元素都包含在一个元素中,以便我们标记反映这两个图像之间的关系,并将它们组合在一起:

 <figud>
  
  <svg xmlns="“" http: viewbox="“">
     
  </svg>
  
  <img src="%E2%80%9C" ... alt="“" loading="“" lazy>
</figud>

我们还需要解决此效果的一些可访问性问题。更具体地说,我们需要为喜欢浏览网络的用户而没有动画和使用屏幕读取器浏览Web的用户进行改进。

使SVG元素可访问需要大量其他标记。此外,如果我们要删除过渡,我们将不得不覆盖相当多的CSS属性,如果我们的选择器特异性不一致,可能会导致问题。幸运的是,我们新添加的常规图像具有出色的可访问性功能,可以轻松地作为无动画浏览网络的用户的替代品。

 <figud>
  
  <svg xmlns="“" http: viewbox="“" aria true>
    
  </svg>

  
  <img src="%E2%80%9C" ... alt="“" loading="“" lazy>
</figud>

我们需要通过添加aria-hidden =“ true”来隐藏辅助设备中的SVG元素,我们需要更新我们的CSS,以包括偏爱的动态媒体查询。我们包含在没有减少运动偏好的情况下隐藏用户的后备图像,同时将其用于屏幕读取器等辅助设备。

 @Media(偏爱降低:无偏爱){
.Fallback-image {
  剪辑:rect(0 0 0 0); 
  剪辑路径:插图(50%);
  身高:1px;
  溢出:隐藏;
  位置:绝对;
  白色空间:nowrap; 
  宽度:1px;
  } 
}

@Media(预先减少的动作){
  。图像 {
    显示:无;
  }
}

这是改进后的结果:

请注意,这些改进不会改变没有偏爱动机偏好集或不使用屏幕读取器的用户的效果和行为。

那是一个包裹

开发人员对夹子路径CSS属性和新样式可能性的路径选项感到兴奋,但是许多人感到不满以发现这些值仅支持像素值。这不仅意味着该功能没有响应,而且严重限制了我们要使用的用例的数量。

我们将有趣的图像弹出悬停效果转换为使用剪辑路径:路径为SVG元素,该元素利用 svg元素的响应能力来实现同一元素。但是这样做,我们引入了一些SEO和可访问性问题,我们设法处理了一些额外的标记和后备图像。

感谢您抽出宝贵的时间阅读本文!让我知道这种方法是否使您了解如何实现自己的效果,以及您是否对如何以不同的方式处理这种效果有任何建议。

以上是让我们使用SVG剪辑路径创建图像弹出效果的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
我们如何标记Google字体并创建Goofonts.com我们如何标记Google字体并创建Goofonts.comApr 12, 2025 pm 12:02 PM

Goofonts是由开发人员和设计师丈夫签名的附带项目,它们都是版式的忠实拥护者。我们一直在标记Google

永恒的Web开发文章永恒的Web开发文章Apr 12, 2025 am 11:44 AM

Pavithra Kodmad向人们询问了他们认为是关于网络开发的一些最永恒的文章的建议

与部分元素的交易与部分元素的交易Apr 12, 2025 am 11:39 AM

同一天发表了两篇文章:

使用JavaScript API的状态练习GraphQl查询使用JavaScript API的状态练习GraphQl查询Apr 12, 2025 am 11:33 AM

学习如何构建GraphQL API可能具有挑战性。但是您可以学习如何在10分钟内使用GraphQL API!碰巧的是,我得到了完美的

组件级CMS组件级CMSApr 12, 2025 am 11:09 AM

当一个组件生活在数据查询居住在附近的数据查询的环境中时,视觉组件与

将类型设置在圆上...带偏移路径将类型设置在圆上...带偏移路径Apr 12, 2025 am 11:00 AM

这里是Yuanchuan的一些合法CSS骗局。有此CSS属性偏移路径。曾几何时,它被称为Motion-Path,然后被更名。我

'恢复”在CSS中有什么作用?'恢复”在CSS中有什么作用?Apr 12, 2025 am 10:59 AM

Miriam Suzanne在Mozilla开发人员的视频中解释了该主题。

现代恋人现代恋人Apr 12, 2025 am 10:58 AM

我喜欢这样的东西。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。