我正在尝试实现一个充满渐变的三角形.
三角形应位于页面的左上角,并拉伸50%的水平视口和120%的垂直视口.
三角形应位于页面的左上角,并拉伸50%的水平视口和120%的垂直视口.
我需要三角形有一个贯穿它的渐变.
我已经设法做了前三件事,但我无法使梯度起作用.
我尝试过以不同的方式定位伪元素溢出和变换:rotate();实现它,但我无法让它工作.
这是迄今为止的JSfiddle:
.triangle { width: 0; height: 0; border-style: solid; border-width: 0px 0 120vh 50vw; border-color: transparent transparent transparent green; }
<div class="triangle"></div>
解决方法
要保持所需的比例,可以使用
inline SVG和preserveAspectRatio =“none”属性(
see MDN).这样,宽度和高度将固定到您使用的视口单元.
您可以使用 polygon element制作三角形,使用 linearGradient element用渐变填充三角形:
您可以使用 polygon element制作三角形,使用 linearGradient element用渐变填充三角形:
svg { width: 50vw; height: 120vh; }
<svg viewBox="0 0 10 10" preserveAspectRatio="none"> <defs> <linearGradient id="gradient"> <stop offset="5%" stop-color="darkorange" /> <stop offset="95%" stop-color="red" /> </linearGradient> </defs> <polygon fill="url(#gradient)" points="0 0 10 0 0 10" /> </svg>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。