iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >怎么用css3中的transform skewX实现平行四边形的导航菜单
  • 766
分享到

怎么用css3中的transform skewX实现平行四边形的导航菜单

2024-04-02 19:04:59 766人浏览 薄情痞子
摘要

本篇内容介绍了“怎么用css3中的transfORM skewX实现平行四边形的导航菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望

本篇内容介绍了“怎么用css3中的transfORM skewX实现平行四边形的导航菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

  平行四边形其实是矩形的超集:它的各条边是两两平行的,但各个角则不一定都是直角。在视觉设计中,平行四边形往往可以传达出一种动感。

  让我们试着用CSS创建一个按钮状的平行四边形链接。我们的起点就是一个普通的块状按钮,辅以一些简单的样式,然后,我们可以通过skew()的变形属性来对这个矩形进行斜向拉伸:

  transform:skewX(-45deg);

  但是,这导致它的内容也发生了斜向变形,这很不好看,而且难读。有没有办法只让容器的形状倾斜,而保持其内容不变呢?

  很多人会想到嵌套元素方案,那么我们可以对内容再应用一次反向的skew()变形,从而抵消容器的变形效果,最终产生我们所期望的结果。不幸的是,这意味着我们将不得不使用一层额外的html元素来包裹内容,比如用一个span:

  <ahref="www.PHP.cn"class="button">

  <span>www.php.cn</span>

  </a>

  .button{transform:skewX(-45deg);}

  .button>span{transform:skewX(45deg);}

  我们可以看到,这个方法的表现很不错,但它也意味着我们不得不添加额外的HTML元素。如果结构层的变更是不允许的,或者你希望严格保持结构层的纯净度,别担心,我们还有一个纯CSS的解决方案。

  伪元素方案

  另一种思路是把所有样式(背景、边框等)应用到伪元素上,然后再对伪元素进行变形。因为我们的内容并不是包含在伪元素里的,所以内容并不会受到变形的影响。下面来看看这个技巧能否得到与前面相同的链接样式。

  我们希望伪元素保持良好的灵活性,可以自动继承其宿主元素的尺寸,甚至当宿主元素的尺寸是由其内容来决定时仍然如此。一个简单的办法是给宿主元素应用position:relative样式,并为伪元素设置position:absolute,然后再把所有偏移量设置为零,以便让它在水平和垂直方向上都被拉伸至宿主元素的尺寸。代码看起来是这样的:

  .button{

  position:relative;

  

  }

  .button::before{

  content:'';

  position:absolute;

  top:0;right:0;bottom:0;left:0;

  }

  此时,用伪元素生成的方块是重叠在内容之上的,一旦给它设置背景,就会遮住内容。为了修复这个问题,我们可以给伪元素设置z-index:-1样式,这样它的堆叠层次就会被推到宿主元素之后。现在我们要做的最后一步,就是尽情地对它设置变形样式,并享受美好的结果。最终版的代码如下所示,它产生的视觉效果跟前文所述技巧是完全一致的:

  .button{

  position:relative;

  

  }

  .button::before{

  content:'';

  position:absolute;

  top:0;right:0;bottom:0;left:0;

  z-index:-1;

  background:#58a;

  transform:skew(45deg);

  }

  这个技巧不仅对skew()变形来说很有用,还适用于其他任何变形样式,当我们想变形一个元素而不想变形它的内容时就可以用到它。举个例子,我们把这个技巧针对rotate()变形样式稍稍调整一下,再用到一个正方形元素上,就可以很容易地得到一个菱形。

  这个技巧的关键在于,我们利用伪元素以及定位属性产生了一个方块,然后对伪元素设置样式,并将其放置在其宿主元素的下层。这种思路同样可以运用在其他场景中,从而得到各种各样的效果。
怎么用css3中的transform skewX实现平行四边形的导航菜单

“怎么用css3中的transform skewX实现平行四边形的导航菜单”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: 怎么用css3中的transform skewX实现平行四边形的导航菜单

本文链接: https://www.lsjlt.com/news/88595.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用css3中的transform skewX实现平行四边形的导航菜单
    本篇内容介绍了“怎么用css3中的transform skewX实现平行四边形的导航菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望...
    99+
    2024-04-02
  • 怎么用纯css3实现的环形导航菜单
    本篇内容介绍了“怎么用纯css3实现的环形导航菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  之前为...
    99+
    2024-04-02
  • 怎么用CSS3实现的黑色个性导航菜单
    这篇文章主要介绍“怎么用CSS3实现的黑色个性导航菜单”,在日常操作中,相信很多人在怎么用CSS3实现的黑色个性导航菜单问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用C...
    99+
    2024-04-02
  • CSS3怎么实现银灰色动画效果的导航菜单
    本篇内容介绍了“CSS3怎么实现银灰色动画效果的导航菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!运行...
    99+
    2024-04-02
  • 怎么使用纯CSS实现圆形导航菜单效果
    小编给大家分享一下怎么使用纯CSS实现圆形导航菜单效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!直接上代码css:body {    background-color:...
    99+
    2023-06-14
  • 用jquery和css3实现的响应式二级导航菜单
    本篇内容介绍了“用jquery和css3实现的响应式二级导航菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2024-04-02
  • 怎么用CSS3实现好看的扇形菜单
    本篇内容介绍了“怎么用CSS3实现好看的扇形菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • 怎么用纯css实现的漂亮导航菜单
    本篇内容介绍了“怎么用纯css实现的漂亮导航菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  今天给大...
    99+
    2024-04-02
  • 怎么用css实现蓝色圆角效果水平导航菜单
    本篇内容主要讲解“怎么用css实现蓝色圆角效果水平导航菜单”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用css实现蓝色圆角效果水平导航菜单”吧!这是一款可...
    99+
    2024-04-02
  • css3怎么实现的多级渐变下拉菜单导航效果代码
    这篇文章主要介绍“css3怎么实现的多级渐变下拉菜单导航效果代码”,在日常操作中,相信很多人在css3怎么实现的多级渐变下拉菜单导航效果代码问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2024-04-02
  • css中如何实现收货地址平行四边形的线条样式
    这篇“css中如何实现收货地址平行四边形的线条样式”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“css中如何实现收货地址平行四边形的线条样式”,小编整理了以下知识点,请大家跟着小编的步伐一步一...
    99+
    2023-06-08
  • Jquery怎么实现带动画效果的二级导航菜单
    要实现带动画效果的二级导航菜单,可以使用jQuery的`slideDown()`和`slideUp()`方法来实现菜单的展开和收起动...
    99+
    2023-08-15
    Jquery
  • 怎么用纯CSS实现菜单、导航栏的3D翻转动画效果
    这篇文章主要讲解了“怎么用纯CSS实现菜单、导航栏的3D翻转动画效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用纯CSS实现菜单、导航栏的3D翻转动...
    99+
    2024-04-02
  • CSS3怎么实现带有飞行效果的三级下拉菜单
    这篇文章主要介绍“CSS3怎么实现带有飞行效果的三级下拉菜单”,在日常操作中,相信很多人在CSS3怎么实现带有飞行效果的三级下拉菜单问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2024-04-02
  • 怎么用HTML+CSS实现一个简单美观的导航栏
    这篇文章主要介绍“怎么用HTML+CSS实现一个简单美观的导航栏”,在日常操作中,相信很多人在怎么用HTML+CSS实现一个简单美观的导航栏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2024-04-02
  • Vue.js中怎么利用递归组件实现一个可折叠的树形菜单
    本篇文章给大家分享的是有关Vue.js中怎么利用递归组件实现一个可折叠的树形菜单,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。在Vue.js中...
    99+
    2024-04-02
  • 车载导航应用中基于Sketch UI主题定制方案的实现是怎么样的
    这篇文章将为大家详细讲解有关车载导航应用中基于Sketch UI主题定制方案的实现是怎么样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.导读关于应用的主题定制,相信大家或多或少都有接触...
    99+
    2023-06-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作