admin管理员组文章数量:1122832
I have four SVG shapes that I am using as text boxes containing a description of courses people can book. At the bottom of the text boxes I want two buttons that have the option to see more information on the course or to book the course. I have tried to create a "foreign object" tag nested in the SVG tags in my html code but this didn't work. I then created button tags that aren't in my SVG tags thinking that I could move the buttons on top of the SVG and just position them so they look contained in the SVG but this has moved the SVG to a different position and I am unsure how to make this collection of elements responsive to different screen sizes. I am a little unsure of what to do from here.
This is the code I have for one of the SVG text boxes:
button.home-course-button {
position:relative;
left: 215px;
bottom: 25px;
border-radius: 15px;
height: 44px;
width: 110px;
}
<svg xmlns="" width="359" height="375" viewBox="0 0 359 375" fill="none" transform="translate(113 40)">
<path d="M2 251.976V306.41M2 306.41V2H274.688L357 75.9886L357 373H84.5L2 306.41Z" stroke="url(#paint0_linear_71_5)" stroke-width="4"/>
<defs>
<linearGradient id="paint0_linear_71_5" x1="179.5" y1="2" x2="179.5" y2="373" gradientUnits="userSpaceOnUse">
<stop stop-color="#37E492"/>
<stop offset="1" stop-color="#008B4A"/>
</linearGradient>
</defs>
<text text-anchor="left" fill="#000000" font-size="31.8px" font-family="Mako" font-weight="400" font-style="normal" x="150" y="38">
</text>
</svg>
<div>
<button class="button home-course-button"><p>See More</p></button>
<button class="button home-course-button"><p>Book</p></button>
</div>
I have four SVG shapes that I am using as text boxes containing a description of courses people can book. At the bottom of the text boxes I want two buttons that have the option to see more information on the course or to book the course. I have tried to create a "foreign object" tag nested in the SVG tags in my html code but this didn't work. I then created button tags that aren't in my SVG tags thinking that I could move the buttons on top of the SVG and just position them so they look contained in the SVG but this has moved the SVG to a different position and I am unsure how to make this collection of elements responsive to different screen sizes. I am a little unsure of what to do from here.
This is the code I have for one of the SVG text boxes:
button.home-course-button {
position:relative;
left: 215px;
bottom: 25px;
border-radius: 15px;
height: 44px;
width: 110px;
}
<svg xmlns="http://www.w3.org/2000/svg" width="359" height="375" viewBox="0 0 359 375" fill="none" transform="translate(113 40)">
<path d="M2 251.976V306.41M2 306.41V2H274.688L357 75.9886L357 373H84.5L2 306.41Z" stroke="url(#paint0_linear_71_5)" stroke-width="4"/>
<defs>
<linearGradient id="paint0_linear_71_5" x1="179.5" y1="2" x2="179.5" y2="373" gradientUnits="userSpaceOnUse">
<stop stop-color="#37E492"/>
<stop offset="1" stop-color="#008B4A"/>
</linearGradient>
</defs>
<text text-anchor="left" fill="#000000" font-size="31.8px" font-family="Mako" font-weight="400" font-style="normal" x="150" y="38">
</text>
</svg>
<div>
<button class="button home-course-button"><p>See More</p></button>
<button class="button home-course-button"><p>Book</p></button>
</div>
I am open to suggestions on easier ways to achieve the same effect as well.
Share Improve this question edited Nov 21, 2024 at 15:00 Fabrizio Calderan 123k26 gold badges170 silver badges182 bronze badges asked Nov 21, 2024 at 14:58 W.ebbW.ebb 11 bronze badge 2 |2 Answers
Reset to default 1You can use the SVG as a CSS background image.
Here, I have the SVG as a data URL, but you could also just refer to a SVG file.
.description {
aspect-ratio: 359 / 375;
width: 359px;
padding: 10px;
background-image: url('');
display: flex;
flex-direction: column;
justify-content: space-between;
}
.buttons {
display: flex;
justify-content: flex-end;
gap: .5em;
}
button.home-course-button {
border-radius: 15px;
height: 44px;
width: 110px;
}
<div class="description">
<div class="text">
<div>Description of the course</div>
</div>
<div class="buttons">
<button class="button home-course-button"><p>See More</p></button>
<button class="button home-course-button"><p>Book</p></button>
</div>
</div>
Use my generator (https://css-generators.com/custom-corners/) to create that shape and you won't need any SVG
.box {
position: relative;
height: 250px;
max-width: 400px;
padding: 15px;
margin: auto;
display: grid;
grid-auto-flow: column;
gap: 10px;
place-content: end;
}
.box:before {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(#37E492,#008B4A);
clip-path: polygon(0 0,calc(100% - 80px) 0,100% 80px,100% 100%,80px 100%,0 calc(100% - 80px),0 0,7px 7px ,7px calc(100% - 80px - 2.9px),calc(80px + 2.9px) calc(100% - 7px),calc(100% - 7px) calc(100% - 7px),calc(100% - 7px) calc(80px + 2.9px),calc(100% - 80px - 2.9px) 7px,7px 7px);
}
<div class="box">
<button class="button home-course-button"><p>See More</p></button>
<button class="button home-course-button"><p>Book</p></button>
</div>
本文标签: htmlIs there a way to nest a button in an SVGStack Overflow
版权声明:本文标题:html - Is there a way to nest a button in an SVG? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736309678a1934104.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
foreignObjects
or by adding eventListeners to svg elements directly – but I highly recommend to prefer HTML elements as inputs/buttons: ForeignObjects have a lot of cross-browser issues and SVG text capabilities are underwhelming (no line wrapping). chrwahl's approach (HTML button on top of a SVG background) should provide a more robust solution. – herrstrietzel Commented Nov 21, 2024 at 19:58