ChatGPT解决这个技术问题 Extra ChatGPT

How to set a stroke-width:1 on only certain sides of SVG shapes?

Setting a stroke-width: 1 on a <rect> element in SVG places a stroke on every side of the rectangle.

How does one place a stroke width on only three sides of an SVG rectangle?


E
Erik Dahlström

If you need stroke or no-stroke then you can also use stroke-dasharray to do this, by making the dashes and gaps match up with the sides of the rectangle.

rect { fill: none; stroke: black; } .top { stroke-dasharray: 0,50,150 } .left { stroke-dasharray: 150,50 } .bottom { stroke-dasharray: 100,50 } .right { stroke-dasharray: 50,50,100 }

See jsfiddle.


How can we show the stroke only on top of the rect element ?
Could you explain why certain numbers in certain positions give this effect?
@JacobIRR refer to the definition of the 'stroke-dasharray' property (linked in the answer). The idea here is to match the dash lengths to the sides of the rectangle, and the dash gap with the side that should have no stroke.
I just updated your solution , in this link codepen.io/shaswatatripathy/pen/oNgPpyd
Here's a programmatic solution that generates stroke-dasharray given an object defining which borders should be shown. Reading the code might help you understand how it works: codepen.io/lazd/pen/WNweNwy?editors=1010
P
Phrogz

You cannot change the visual style of various parts of a single shape in SVG (absence the not-yet-available Vector Effects module). Instead, you will need to create separate shapes for each stroke or other visual style that you want to vary.

Specifically for this case, instead of using a <rect> or <polygon> element you can create a <path> or <polyline> that only covers three sides of the rectangle:

<!-- Move to 50,50 then draw a line to 150,50, to 150,150, and then to 50,150 -->
<path d="M50,50 L150,50 150,150 50,150" />
<polyline points="50,50 150,50 150,150 50,150" />

You can see the effect of these in action here: http://jsfiddle.net/b5FrF/3/

https://i.stack.imgur.com/2sqMu.png

For more information, read about the <polyline> and more-powerful-but-more-confusing <path> shapes.


w
wdebeaum

You could use a polyline for the three stroked sides, and just not put the stroke on the rectangle at all. I don't think SVG lets you apply different strokes to different parts of a path/shape, so you need to use multiple objects to get the same effect.