html5&css&js代码 033 SVG元素示例

html5&css&js代码 033 SVG元素示例

一个SVG图形,该图形由一个椭圆、一个圆形和一个矩形组成。

一、代码

复制代码
<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <title>编程笔记 html5&css&js SVG元素示例</title>
    <meta charset="utf-8"/>
    <style>
        /* 设置页面字体颜色和背景颜色 */
        body {
            color: cyan;
            background-color: teal;
        }

        /* 定义容器的样式,包括内边距、宽度、自动居中和高度 */
        .container {
            padding: 100px; /* 容器内边距 */
            width: 70%; /* 设置容器的宽度 */
            margin: 0 auto; /* 将左右边距设置为自动,实现居中 */
            height: 80%; /* 容器高度 */
            text-align: center; /* 文本居中 */
        }

    </style>
</head>
<body>
<div class="container">
    <!-- SVG示例,包含一个椭圆、一个圆形和一个矩形 -->
    <h1>这是一个SVG画的椭圆</h1>
    <svg height="600" width="1200">
        <!-- 椭圆元素,中心点为(600, 240),长轴半径为300,短轴半径为200,填充色为黄色,边框色为紫色,边框宽度为2 -->
        <ellipse
                cx="600"
                cy="240"
                rx="300"
                ry="200"
                style="fill: yellow; stroke: purple; stroke-width: 2"/>
        <!-- 圆形元素,圆心为(700, 240),半径为150,填充色为绿色,边框色为黑色,边框宽度为2 -->
        <circle r="150" cx="700" cy="240" fill="green" stroke="black" stroke-width="2"/>
        <!-- 矩形元素,左上角坐标为(200, 140),宽度为300,高度为200,填充色为红色,边框色为黑色,边框宽度为2 -->
        <rect x="200" y="140" width="300" height="200" fill="red" stroke="black" stroke-width="2"/>
    </svg>
</div>
</body>
</html>

二、解释

SVG(Scalable Vector Graphics)是一种基于XML的图像格式,用于描述二维矢量图形。在HTML中,SVG元素允许开发者在网页上直接嵌入矢量图形,这些图形可以是图标、插图、图表等。SVG的主要优势在于它们的可伸缩性:无论放大还是缩小,SVG图形都能保持清晰的边缘和线条,不会出现像素化的问题,这使得SVG非常适合用于响应式设计。

SVG元素的基本结构如下:

html 复制代码
<svg width="100" height="100">
  <!-- SVG内容,如形状、路径、文本等 -->
</svg>

在这个例子中,<svg> 标签定义了一个SVG图形的容器,widthheight 属性定义了图形的尺寸。在<svg> 标签内部,可以包含各种子元素来创建图形,例如:

  • <circle>:创建圆形。
  • <rect>:创建矩形。
  • <line>:创建直线。
  • <path>:创建复杂的路径。
  • <text>:添加文本。
  • <image>:嵌入图像。
    SVG还支持CSS和JavaScript,这意味着你可以使用CSS来为SVG元素添加样式,或者使用JavaScript来动态操作SVG元素。
    一个简单的SVG图形示例:
html 复制代码
<svg width="100" height="100">
  <circle cx="50" cy="50" r="40" stroke="green" stroke-width="4" fill="yellow" />
</svg>

这个例子创建了一个中心位于(50, 50)、半径为40的黄色圆形,圆周有一条宽度为4、颜色为绿色的边框。

SVG是Web标准的一部分,得到了所有现代浏览器的支持,因此它是在网页上展示矢量图形的理想选择。

相关推荐
炫饭第一名7 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
不会敲代码18 小时前
前端组件化样式隔离实战:React CSS Modules、styled-components 与 Vue scoped 对比
css·vue.js·react.js
进击的尘埃9 小时前
Vue3 响应式原理:从 Proxy 到依赖收集,手撸一个迷你 reactivity
javascript
willow9 小时前
JavaScript数据类型整理1
javascript
LeeYaMaster9 小时前
20个例子掌握RxJS——第十一章实现 WebSocket 消息节流
javascript·angular.js
UIUV10 小时前
RAG技术学习笔记(含实操解析)
javascript·langchain·llm
颜酱12 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
Sailing12 小时前
🚀 别再乱写 16px 了!CSS 单位体系已经进入“计算时代”,真正的响应式布局
前端·css·面试
FansUnion12 小时前
我如何用 Next.js + Supabase + Cloudflare R2 搭建壁纸销售平台——月成本接近 $0
javascript
左夕13 小时前
分不清apply,bind,call?看这篇文章就够了
前端·javascript