gpt4 book ai didi

html - 水平倾斜元素但恰好在右侧

转载 作者:太空宇宙 更新时间:2023-11-04 13:18:41 24 4
gpt4 key购买 nike

我想借助 HTML 5 和 CSS 3 进行如下设计。这里是 jsfiddle我是怎么做到的。

enter image description here

这是示例代码

<div class="header">Akşam Sizin İçin Önerdiklerimiz
<div class="skew"></div>
</div>
<div class="line"></div>

.header {
color: white;
font-size: 14px;
display: inline-block;
padding: 5px 10px;
background-color: #6b6a69;
position: relative;
}
.skew {
position: absolute;
-moz-transform: skewX(45deg);
-ms-transform: skewX(45deg);
-o-transform: skewX(45deg);
-webkit-transform: skewX(45deg);
transform: skewX(45deg);
right: -14px;
display: inline-block;
width: 40px;
height: 30px;
top: 0;
background: inherit;
z-index: -1;
}
.line {
height: 11px;
background-color: #6b6a69;
margin-top: -7px;
}

如您所见,我使用了 3 个 html 元素来构建它。我想要实现的是为整个设计提供渐变背景色。但是有 3 个不同的元素,所以我只能分别为每个元素应用渐变,这看起来不像我想要的那样。

所以我试图通过 CSS 3 功能(如转换)仅通过 1 个元素来实现该设计。至少通过删除 div.skew 元素只倾斜图片中的右侧对我来说是一个改进。

如果可以,那我该怎么做呢?

编辑:这里是 example当我应用渐变时它看起来如何,这就是为什么我想简单地删除额外的元素以将渐变应用于整个设计。

最佳答案

这将是一种更简单的方法:http://codepen.io/pageaffairs/pen/aDoFc

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<style>

.header {
color: white;
font-size: 14px;
padding: 0 0 20px 0;
background-color: #6b6a69;
position: relative;
background: -moz-linear-gradient(left, rgba(30,87,153,1) 0%, rgba(180,187,193,1) 100%); /* FF3.6+ */
background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(30,87,153,1)), color-stop(100%,rgba(180,187,193,1))); /* Chrome,Safari4+ */
background: -webkit-linear-gradient(left, rgba(30,87,153,1) 0%,rgba(180,187,193,1) 100%);
background: -o-linear-gradient(left, rgba(30,87,153,1) 0%,rgba(180,187,193,1) 100%); /* Opera 11.10+ */
background: -ms-linear-gradient(left, rgba(30,87,153,1) 0%,rgba(180,187,193,1) 100%); /* IE10+ */
background: linear-gradient(to right, rgba(30,87,153,1) 0%,rgba(180,187,193,1) 100%); /* W3C */
overflow: hidden;
}

span {position: relative; display: inline-block; padding: 5px 10px 0 10px;}
span:after {
content: " ";
width: 2000px;
height: 0;
position: absolute;
border-top: 20px solid white;
border-right: 0 solid transparent;
border-bottom: 0 solid transparent;
border-left: 20px solid transparent;
left: 100%;
top: 0;
}

</style>
</head>
<body>

<div class="header">
<span>Akşam Sizin İçin Önerdiklerimiz</span>
</div>

</body>
</html>

关于html - 水平倾斜元素但恰好在右侧,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24216625/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com