viewport
viewport就是svg 设置width与height的范围,这个with与height将是浏览器显示的大小
<svg width="10%" height="10%" style="background-color: #b2bbc0">
<rect x="0" y="0" width="50" height="50" fill="#234234"></rect>
</svg>
<svg width="5%" height="5%" style="background-color: #b2bbc0">
<rect x="0" y="0" width="50" height="50" fill="#234234"></rect>
</svg>
data:image/s3,"s3://crabby-images/76626/76626a3f18e1041e2f920127178f5340684e4a73" alt=""
viewBox
viewBox将告诉svg只能在这个区域内绘制,内部的路径坐标都是按照viewBox的坐标计算
没有设置viewBox的时候,viewBox就是viewport的大小
<svg width="10%" height="10%" style="background-color: #b2bbc0" viewBox="0,0,200,200">
<rect x="0" y="0" width="50" height="50" fill="#234234"></rect>
</svg>
<svg width="5%" height="5%" style="background-color: #b2bbc0" viewBox="0,0,200,200">
<rect x="0" y="0" width="50" height="50" fill="#234234"></rect>
</svg>
data:image/s3,"s3://crabby-images/aaa3d/aaa3dd36478befa2d5e835b993d3ea4782f4d79b" alt=""
viewBox会缩放到viewport的大小,如果比例不同,就会有裁剪,这时可以用到preserveAspectRatio
preserveAspectRatio
preserveAspectRatio需要配合viewBox使用,第一个参数是必填的对齐方式,第二个参数是meetOrSlice
preserveAspectRatio="<align> [<meetOrSlice>]"
不加preserveAspectRatio,viewbox会缩放到viewport大小
<svg width="300" height="200" style="border:1px solid; background:#fff;" viewbox="0,0,100,160">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/97f7a/97f7a6c9ff49da24521a3902a5a2f52ea6a9ac13" alt=""
- xMinYMin svg内容靠左对齐
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMinYMin meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/8e755/8e755800c0b609dbab6123e6549a00d2f38c6ec2" alt=""
- xMidYMin
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMidYMin meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/75d76/75d761aeb0c0b0fa378afe68df8cf25375fd14a9" alt=""
- xMaxYMin
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMaxYMin meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/ac77d/ac77d276bf91cf9e4893ad9a1556305266a1ee5d" alt=""
- xMinYMid
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMinYMid meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/256d5/256d594e09fa4e9db96692a8737f154ce735cd85" alt=""
- xMidYMid
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMidYMid meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/7d381/7d381e4518151085050b4c744aae7d90744f83f2" alt=""
- xMaxYMid
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMaxYMid meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/27133/271331169ea5bfb267bb0945f7f386119dbfe4fa" alt=""
- xMinYMax
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMinYMax meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/4e64b/4e64bcf0ddacdf3104d9e1de042eda0c302c3a3b" alt=""
- xMidYMax
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMidYMax meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/40965/409657870ee090c63866635f398d5536cf85c6b8" alt=""
- xMaxYMax
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMaxYMax meet">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/ed836/ed836cfc59d81784d960b2bca81e8090bb77582d" alt=""
meetOrSlice
- slice
等比缩放,直到填充viewport,超出部分会被裁掉
<svg width="300" height="200" style="border:1px solid; background:#fff;"
viewbox="0,0,100,160" preserveAspectRatio="xMaxYMax slice">
<rect width="40" height="30" x="0" y="0" fill="#c00"></rect>
<rect width="40" height="30" x="60" y="0" fill="#f80"></rect>
<rect width="40" height="30" x="0" y="130" fill="#09c"></rect>
<rect width="40" height="30" x="60" y="130" fill="#0c0"></rect>
<rect width="40" height="30" x="30" y="65" fill="#000"></rect>
</svg>
data:image/s3,"s3://crabby-images/bb553/bb55308bbb1b9027ebaefd580f386fa57769ad45" alt=""
- meet
等比缩放,直到高度或者宽度达到viewport
网友评论