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

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

transform: skewX(-45deg);

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

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

www.w3cbest.com

.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() 变形样式稍稍调整一下,再用到一个正方形元素上,就可以很容易地得到一个菱形。

这个技巧的关键在于,我们利用伪元素以及定位属性产生了一个方块,然后对伪元素设置样式,并将其放置在其宿主元素的下层。这种思路同样可以运用在其他场景中,从而得到各种各样的效果。

python画平行四边形_利用transform skewX制作平行四边形导航菜单相关推荐

  1. 利用python画曲线_利用python画出AUC曲线的实例

    以load_breast_cancer数据集为例,模型细节不重要,重点是画AUC的代码.1XS免费资源网 直接上代码:1XS免费资源网 from sklearn.datasets import loa ...

  2. 利用python画曲线_利用Python绘制血药浓度-时间曲线——口服吸收一室模型

    血药浓度-时间曲线一般是通过拟合所测定的血药浓度点而画出来的,但是在某些时候,如阅读文献时,我们需要根据别人报道的PK参数来画出药时曲线.Python语法简单,拥有丰富的开源库,下面尝试通过Pytho ...

  3. 使用python画图表_利用Python绘制数据的瀑布图的教程

    介绍 对于绘制某些类型的数据来说,瀑布图是一种十分有用的工具.不足为奇的是,我们可以使用Pandas和matplotlib创建一个可重复的瀑布图. 在往下进行之前,我想先告诉大家我指代的是哪种类型的图 ...

  4. python画猫和老鼠_利用python如何实现猫捉老鼠小游戏

    python实现猫捉老鼠小游戏 首界面 开始游戏界面 然后键盘操作小老鼠上下左右移动,猫自己去追,当猫追上老鼠则游戏结束 这里用时3.2秒,最后将游戏时长与猫和老鼠都显示在主页面上 下面我把猫与老鼠的 ...

  5. 用python画猫和老鼠_利用python如何实现猫捉老鼠小游戏

    python实现猫捉老鼠小游戏 首界面 开始游戏界面 然后键盘操作小老鼠上下左右移动,猫自己去追,当猫追上老鼠则游戏结束 这里用时3.2秒,最后将游戏时长与猫和老鼠都显示在主页面上 下面我把猫与老鼠的 ...

  6. python画小猪_利用python画小猪佩奇

    importturtle as t t.pensize(4) t.hideturtle() t.colormode(255) t.color((255,155,192),"pink" ...

  7. 利用transform:rotate( )制作折扇

    跟大家分享一个利用transform:rotate( )制作折扇小案例的过程! 制作思路:扇子是由一个个不同颜色的小长方形围绕自身相同的旋转原点旋转而成的.所有的小方块都是在一个大方块里,只是大方块没 ...

  8. 利用3D效果制作立体导航栏

    利用3D效果制作立体导航栏 文章目录 使用3D效果制作3D导航栏 一.3D的旋转以及位移 二.使用步骤 1.搭建html骨架 2.添加css样式 前言 利用3D效果制作导航栏: 制作一个好玩的3D导航 ...

  9. HTML中spry菜单栏,DreamweaverCS3中用“spry菜单栏”制作纵向导航菜单.docx

    Dreamweaver CS3 中用" spry 菜单栏"制作纵向导航菜单 摘要:网页导航菜单是指引和方便浏览者访问所需内 容的快速通道.该文介绍了Dreamweaver CS3 ...

  10. alibaba外贸平台国际站装修导航店招全屏代码视频教程分享经验阿里巴巴国际站全屏店招通栏店招国际站外贸平台装修店招设置如何制作1920导航菜单自定义内容店招宽屏店招加链接

    阿里巴巴国际站全屏店招通栏店招国际站外贸平台装修店招设置如何制作1920导航菜单自定义内容店招宽屏店招加链接 装修工具:一秒美工助手工具

最新文章

  1. 《未来企业效率白皮书》
  2. IOS 获取缓存目录文件大小并清除
  3. python获取数组中大于某一阈值的那些索引值_java矩阵计算及其在统计中的应用(一)...
  4. Hdu 4738 Caocao's Bridges (连通图+桥)
  5. 元宇宙iwemeta:元宇宙催生新的行业机会,看看你能抓住哪些机遇?
  6. 【转】android之在activity中控制另一个activity的UI更新_如何在activity之间传递handler...
  7. 466. 统计重复个数 golang[转]
  8. JavaScript 中,break , continue , return 的区别
  9. linux cd 一些用法
  10. 三星Galaxy S22 Ultra渲染图曝光:有Note系列的味道
  11. [CTO札记]第1天:认识人、熟悉环境
  12. STL常用函数总结-queue+priority_queue
  13. 【原创】 Boost序列化自己手写实现简易版
  14. Silverlight4.0教程之与摄像头与迈克风设备交互
  15. VisualSVN-Server 安装以及使用教程
  16. Vue一级二级三级域名下cookie值共享(不同域名cookie共享)
  17. html中网站片头制作利器,视频开头特效制作 视频播放时简单的片头制作
  18. win10配置计算机时强制关机,win10系统强制关机后开不了机了的解决方案
  19. 根据ISBN查询图书信息
  20. unreal虚幻引擎学习(一)史上最全的Unreal Engine 4学习资料整理

热门文章

  1. 《带您走进西藏》网课章节测验及答案
  2. html5设置视频显示第一帧,【前端】如何在video上显示视频的第一帧
  3. 手把手教你用keras搭建GAN
  4. SQLAlchemy部分
  5. 【Python游戏】Python实现一个雷霆战机游戏 | 附带源码
  6. Android手机截图怎么做,怎样在手机上截图(安卓手机、苹果手机截图方法)
  7. 支付宝转账到银行卡的功能测试点
  8. SuperView和View的区别
  9. DDos-Attack攻击器教程(kali linux)
  10. win7系统快捷键操作大全