时间:2021-05-08
本文介绍了CSS 实现平行四边形的示例代码,分享给大家,具体如下:
先上效果图
平行四边形可以用做导航栏部分。
原理:利用transform属性拉伸矩形。
CSS代码
transform: skewX(-45deg);上面的代码表示:沿X轴倾斜 -45 度。
但如果只用上面的代码作用在元素上,会导致其内容也发生倾斜变形,会影响阅读。
解决方法1:嵌套元素
用嵌套元素的方法,对内容再应用一次反向的 skew() 变形,从而抵消容器对内容产生的变形效果。
HTML代码
<a href="http://suo.im/1yaTY3"> <div>HOME</div></a>CSS代码
a { width: 100px; height: 40px; display: flex; justify-content: center; align-items: center; background: #58a; text-decoration: none; color: #fff; transform: skewX(-45deg);}div { transform: skewX(45deg);}效果如图所示
这种方法在表现上很不错,不过在逻辑上比较直接粗暴。
我们理解的HTML,更应该作用在框架的搭建上,而不是样式的表现上。如果结构层的更变是不允许的,或者希望严格保持结构层的纯净度,这种方法不是好方法。
注意:像上面的例子中,如果想把布局的样式用在a(内联元素)里,记得把它的display设成inline-block或block等值,否则变形不会生效。
这里我设置成flex,为了方便把内容居中。
解决方法二:伪元素
把所有样式应用到伪元素上,然后再对伪元素进行变形。
内容层(文字部分)只做颜色、字号等设置。
HTML代码
<a href="http://suo.im/1yaTY3"> HOME</a>CSS代码
a::before { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: -1; background: #58a; transform: skewX(-45deg);}a { width: 100px; height: 40px; position: relative; display: flex; justify-content: center; align-items: center; color: #fff; text-decoration: none;}也能得到同样的效果。这种方法不会污染HTML结构层。
这种方法为伪元素保持了良好的灵活性,可以自动继承其宿主元素的尺寸。
首先给宿主元素应用 position: relative 样式,并为伪元素设置 position: absolute,然后再把所有偏移量设置为0,以便让它在水平和垂直方向上都被拉伸至宿主元素的尺寸(top: 0; right: 0; bottom: 0; left: 0;)。
此时,用伪元素生成的方块是重叠在内容之上的,一旦给它设置背景,就会遮住内容。所以要为伪元素设置 z-index: -1 。这样它的堆叠层次就会被推到宿主元素之后。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Scratch中想要绘制一个平行四边形,平行四边形的各边、各内角不一定相等,所以它的画法与正方形和正三角形稍有不同。具体该怎么绘制呢?下面我们就来看看Scrat
平行四边形其实是矩形的超集:它的各条边是两两平行的,但各个角则不一定都是直角。在视觉设计中,平行四边形往往可以传达出一种动感。让我们试着用CSS创建一个按钮状的
ppt中想要制作一个折页效果的流程图,像是纸条围绕时间轴的效果,我们可以通过平行四边形和矩形的组合,得到平行四边形折纸效果,再添加文字和箭头,得到表示流程关系的
代码如下所示://收货地址的平行四边形的线条样式//样式.top{background-color:#fff;position:relative;}.top:b
五年级数学课中,三角形转换为平行四边形的一个课件。完全相同的两个三角形,将其中一个移动、旋转、重新排列后,组合成平行四边形。老师的讲解过程会有提问、启发等必