1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
|
---
title: SVGSVGElement
slug: Web/API/SVGSVGElement
translation_of: Web/API/SVGSVGElement
---
<div><font><font>{{APIRef("SVG")}}</font></font></div>
<p><font><font>该</font></font><strong><code>SVGSVGElement</code></strong><font><font>接口提供对{{SVGElement("svg")}}元素的属性的访问,以及操作它们的方法。</font><font>此接口还包含各种常用的实用方法,例如矩阵操作和控制可视渲染设备上重绘时间的功能。</font></font></p>
<p><font><font>{{InheritanceDiagram(600,140)}}</font></font></p>
<h2 id="属性"><font><font>属性</font></font></h2>
<p><em><font><font>此接口还从其父</font></font></em> <em>{{domxref("SVGGraphicsElement")}}</em> <em><font><font>继承属性,并且还实现</font></font></em> <em>{{domxref("SVGZoomAndPan")}}</em> <em><font><font>,</font></font></em> <em>{{domxref("SVGFitToViewBox")}}</em> <em><font><font>和</font></font></em> <em> {{domxref("WindowEventHandlers")}}</em> <em><font><font>中的属性。</font></font></em></p>
<dl>
<dt>{{domxref("SVGSVGElement.x")}} {{ReadOnlyInline}}</dt>
<dd> {{domxref("SVGAnimatedLength")}} 对应于给定 {{SVGElement("svg")}} 元素的 {{SVGAttr("x")}} 属性</dd>
<dt><font>{{domxref("SVGSVGElement.y")}} {{ReadOnlyInline}}</font></dt>
<dd><font><font>{{domxref("SVGAnimatedLength")}}对应于给定{{SVGElement("svg")}}元素的{{SVGAttr("y")}}属性。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.width")}} {{ReadOnlyInline}}</font></font></dt>
<dd><font><font>{{domxref("SVGAnimatedLength")}}对应于给定{{SVGElement("svg")}}元素的{{SVGAttr("width")}}属性。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.height")}} {{ReadOnlyInline}}</font></font></dt>
<dd><font><font>{{domxref("SVGAnimatedLength")}}对应于给定{{SVGElement("svg")}}元素的{{SVGAttr("height")}}属性。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.contentScriptType")}}</font></font></dt>
<dd><font><font>{{domxref("SVGAnimatedLength")}}对应于给定{{SVGElement("svg")}}元素的{{SVGAttr("contentScriptType")}}属性。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.contentStyleType")}}</font></font></dt>
<dd><font><font>{{domxref("SVGAnimatedLength")}}对应于给定{{SVGElement("svg")}}元素的{{SVGAttr("contentStyleType")}}属性。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.viewport")}}</font></font></dt>
<dd><font><font>一个{{domxref("SVGRect")}},包含与给定{{SVGElement("svg")}}元素对应的视口(隐式或显式)的位置和大小。</font><font>当浏览器实际呈现内容时,位置和大小值表示呈现时的实际值。</font><font>位置和大小值是父元素坐标系中的无单位值。</font><font>如果不存在父元素(即{{SVGElement("svg")}}元素表示文档树的根),如果此SVG文档作为另一文档的一部分嵌入(例如,通过HTML {{HTMLElement(" object")}} element),然后位置和大小是父文档坐标系中的无单位值。</font><font>(如果父级使用CSS或XSL布局,</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.pixelUnitToMillimeterX")}} {{deprecated_inline}}</font></font></dt>
<dd><font><font>一个浮点数,表示沿视口x轴的像素单位(由CSS2定义)的大小,表示70dpi到120dpi范围内的某个单位,并且在支持此功能的系统上,可能实际上与特征匹配目标媒体。</font><font>在不可能知道像素大小的系统上,提供合适的默认像素大小。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.pixelUnitToMillimeterY")}} {{deprecated_inline}}</font></font></dt>
<dd><font><font>浮点数,表示沿视口y轴的像素单位大小。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.screenPixelToMillimeterX")}} {{deprecated_inline}}</font></font></dt>
<dd><font><font>DOM级别2中的用户界面(UI)事件指示给定UI事件发生的屏幕位置。</font><font>当浏览器实际知道“屏幕单元”的物理尺寸时,此浮动属性将表示该信息; </font><font>否则,用户代理将提供合适的默认值,例如.28mm。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.screenPixelToMillimeterY")}} {{deprecated_inline}}</font></font></dt>
<dd><font><font>沿着视口的y轴的屏幕像素的对应大小。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.useCurrentView")}}</font></font></dt>
<dd><font><font>当前最内层SVG文档片段的初始视图(即放大和平移之前)可以是“标准”视图,即基于{{SVGElement("svg")}}元素的属性,例如{{SVGAttr ("viewBox")}})或“自定义”视图(即指向特定{{SVGElement("view")}}或其他元素的超链接)。</font><font>如果初始视图是“标准”视图,则此属性为</font></font><code>false</code><font><font>。</font><font>如果初始视图是“自定义”视图,则此属性为</font></font><code>true</code><font><font>。</font></font></dd>
<dt><font><font>{{domxref("SVGSVGElement.currentView")}}</font></font></dt>
<dd><font><font>{{domxref("SVGViewSpec")}}定义当前最里面的SVG文档片段的初始视图(即,放大和平移之前)。</font><font>意义取决于具体情况:如果初始视图是“标准”视图,则:</font></font>
<ul>
<li><font><font>{{SVGAttr("viewBox")}},{{SVGAttr("preserveAspectRatio")}}和{{SVGAttr("currentView")}}中的{{SVGAttr("zoomAndPan")}}的值将与值匹配对于</font></font><code>SVGSVGElement</code><font><font>直接</font><font>打开的相应DOM属性</font></font></li>
<li><font><font>} {{SVGAttr("currentView")}}中的{{SVGAttr("transform")}}和{{SVGAttr("viewTarget")}}的值将为null</font></font></li>
</ul>
<font><font> 如果初始视图是{{SVGElement("view")}}元素的链接,那么:</font></font>
<ul>
<li><font><font>在{{SVGAttr("currentView")}}中{{SVGAttr("viewBox")}},{{SVGAttr("preserveAspectRatio")}}和{{SVGAttr("zoomAndPan")}}的值将对应于给定{{SVGElement("view")}}元素的相应属性</font></font></li>
<li><font><font>} {{SVGAttr("currentView")}}中的{{SVGAttr("transform")}}和{{SVGAttr("viewTarget")}}的值将为null</font></font></li>
</ul>
<font><font> 如果初始视图是指向另一个元素的链接(即,除了{{SVGElement("view")}}}之外的其他元素,则:</font></font>
<ul>
<li><font><font>{{SVGAttr("viewBox")}},{{SVGAttr("preserveAspectRatio")}}和{{SVGAttr("currentView")}}中的{{SVGAttr("zoomAndPan")}}的值将与值匹配对于</font></font><code>SVGSVGElement</code><font><font>直接用于最近祖先{{SVGElement("svg")}}元素</font><font>的相应DOM属性</font></font></li>
<li><font><font>{{SVGAttr("currentView")}}中{{SVGAttr("transform")}}的值将为null</font></font></li>
<li><font><font>{{SVGAttr("currentView")}}中的{{SVGAttr("viewTarget")}}将代表链接的目标</font></font></li>
</ul>
<font><font> 如果初始视图是使用SVG视图规范片段标识符(即#svgView(...))链接到SVG文档片段,则:</font></font>
<ul>
<li>the values for {{SVGAttr("viewBox")}}, {{SVGAttr("preserveAspectRatio")}}, {{SVGAttr("zoomAndPan")}}, {{SVGAttr("transform")}} and {{SVGAttr("viewTarget")}} within {{SVGAttr("currentView")}} will correspond to the values from the SVG view specification fragment identifier</li>
</ul>
</dd>
<dt>{{domxref("SVGSVGElement.currentScale")}}</dt>
<dd>On an outermost {{SVGElement("svg")}} element, this float attribute indicates the current scale factor relative to the initial view to take into account user magnification and panning operations. DOM attributes <code>currentScale</code> and <code>currentTranslate</code> are equivalent to the 2x3 matrix <code>[a b c d e f] = [currentScale 0 0 currentScale currentTranslate.x currentTranslate.y]</code>. If "magnification" is enabled (i.e., <code>zoomAndPan="magnify"</code>), then the effect is as if an extra transformation were placed at the outermost level on the SVG document fragment (i.e., outside the outermost {{SVGElement("svg")}} element).</dd>
<dt>{{domxref("SVGSVGElement.currentTranslate")}} {{ReadOnlyInline}}</dt>
<dd>An {{domxref("SVGPoint")}} representing the translation factor that takes into account user "magnification" corresponding to an outermost {{SVGElement("svg")}} element. The behavior is undefined for <svg> elements that are not at the outermost level.</dd>
</dl>
<h2 id="Methods">Methods</h2>
<p><em>This interface also inherits methods from its parent, {{domxref("SVGGraphicsElement")}} and also implements the ones from {{domxref("SVGZoomAndPan")}}, {{domxref("SVGFitToViewBox")}}, and {{domxref("WindowEventHandlers")}}.</em></p>
<dl>
<dt>{{domxref("SVGSVGElement.suspendRedraw()")}} {{deprecated_inline}}</dt>
<dd>
<p>Takes a time-out value which indicates that redraw shall not occur until:</p>
the corresponding unsuspendRedraw() call has been made, an unsuspendRedrawAll() call has been made, or its timer has timed out.
<p>In environments that do not support interactivity (e.g., print media), then redraw shall not be suspended. Calls to <code>suspendRedraw()</code> and <code>unsuspendRedraw()</code> should, but need not be, made in balanced pairs.</p>
<p>To suspend redraw actions as a collection of SVG DOM changes occur, precede the changes to the SVG DOM with a method call similar to:</p>
<pre class="brush: js">suspendHandleID = suspendRedraw(maxWaitMilliseconds);</pre>
<p>and follow the changes with a method call similar to:</p>
<pre class="brush: js">unsuspendRedraw(suspendHandleID);</pre>
<p>Note that multiple suspendRedraw calls can be used at once and that each such method call is treated independently of the other suspendRedraw method calls.</p>
</dd>
<dt>{{domxref("SVGSVGElement.unsuspendRedraw()")}} {{deprecated_inline}}</dt>
<dd>Cancels a specified <code>suspendRedraw()</code> by providing a unique suspend handle ID that was returned by a previous <code>suspendRedraw()</code> call.</dd>
<dt>{{domxref("SVGSVGElement.unsuspendRedrawAll()")}} {{deprecated_inline}}</dt>
<dd>Cancels all currently active <code>suspendRedraw()</code> method calls. This method is most useful at the very end of a set of SVG DOM calls to ensure that all pending <code>suspendRedraw()</code> method calls have been cancelled.</dd>
<dt>{{domxref("SVGSVGElement.forceRedraw()")}} {{deprecated_inline}}</dt>
<dd>In rendering environments supporting interactivity, forces the user agent to immediately redraw all regions of the viewport that require updating.</dd>
<dt>{{domxref("SVGSVGElement.pauseAnimations()")}}</dt>
<dd>Suspends (i.e., pauses) all currently running animations that are defined within the SVG document fragment corresponding to this {{SVGElement("svg")}} element, causing the animation clock corresponding to this document fragment to stand still until it is unpaused.</dd>
<dt>{{domxref("SVGSVGElement.unpauseAnimations()")}}</dt>
<dd>Unsuspends (i.e., unpauses) currently running animations that are defined within the SVG document fragment, causing the animation clock to continue from the time at which it was suspended.</dd>
<dt>{{domxref("SVGSVGElement.animationsPaused()")}}</dt>
<dd>Returns true if this SVG document fragment is in a paused state.</dd>
<dt>{{domxref("SVGSVGElement.getCurrentTime()")}}</dt>
<dd>Returns the current time in seconds relative to the start time for the current SVG document fragment. If getCurrentTime is called before the document timeline has begun (for example, by script running in a {{SVGElement("script")}} element before the document's SVGLoad event is dispatched), then 0 is returned.</dd>
<dt>{{domxref("SVGSVGElement.setCurrentTime()")}}</dt>
<dd>Adjusts the clock for this SVG document fragment, establishing a new current time. If <code>setCurrentTime</code> is called before the document timeline has begun (for example, by script running in a {{SVGElement("script")}} element before the document's SVGLoad event is dispatched), then the value of seconds in the last invocation of the method gives the time that the document will seek to once the document timeline has begun.</dd>
<dt>{{domxref("SVGSVGElement.getIntersectionList()")}}</dt>
<dd>Returns a {{domxref("NodeList")}} of graphics elements whose rendered content intersects the supplied rectangle. Each candidate graphics element is to be considered a match only if the same graphics element can be a target of pointer events as defined in {{SVGAttr("pointer-events")}} processing.</dd>
<dt>{{domxref("SVGSVGElement.getEnclosureList()")}}</dt>
<dd>Returns a {{domxref("NodeList")}} of graphics elements whose rendered content is entirely contained within the supplied rectangle. Each candidate graphics element is to be considered a match only if the same graphics element can be a target of pointer events as defined in {{SVGAttr("pointer-events")}} processing.</dd>
<dt>{{domxref("SVGSVGElement.checkIntersection()")}}</dt>
<dd>Returns <code>true</code> if the rendered content of the given element intersects the supplied rectangle. Each candidate graphics element is to be considered a match only if the same graphics element can be a target of pointer events as defined in {{SVGAttr("pointer-events")}} processing.</dd>
<dt>{{domxref("SVGSVGElement.checkEnclosure()")}}</dt>
<dd>Returns <code>true</code> if the rendered content of the given element is entirely contained within the supplied rectangle. Each candidate graphics element is to be considered a match only if the same graphics element can be a target of pointer events as defined in {{SVGAttr("pointer-events")}} processing.</dd>
<dt>{{domxref("SVGSVGElement.deselectAll()")}}</dt>
<dd>Unselects any selected objects, including any selections of text strings and type-in bars.</dd>
<dt>{{domxref("SVGSVGElement.createSVGNumber()")}}</dt>
<dd>Creates an {{domxref("SVGNumber")}} object outside of any document trees. The object is initialized to a value of zero.</dd>
<dt>{{domxref("SVGSVGElement.createSVGLength()")}}</dt>
<dd>Creates an {{domxref("SVGLength")}} object outside of any document trees. The object is initialized to a value of zero user units.</dd>
<dt>{{domxref("SVGSVGElement.createSVGAngle()")}}</dt>
<dd>Creates an {{domxref("SVGAngle")}} object outside of any document trees. The object is initialized to a value of zero degrees (unitless).</dd>
<dt>{{domxref("SVGSVGElement.createSVGPoint()")}}</dt>
<dd>Creates an {{domxref("SVGPoint")}} object outside of any document trees. The object is initialized to the point (0,0) in the user coordinate system.</dd>
<dt>{{domxref("SVGSVGElement.createSVGMatrix()")}}</dt>
<dd>Creates an {{domxref("SVGMatrix")}} object outside of any document trees. The object is initialized to the identity matrix.</dd>
<dt>{{domxref("SVGSVGElement.createSVGRect()")}}</dt>
<dd>Creates an {{domxref("SVGRect")}} object outside of any document trees. The object is initialized such that all values are set to 0 user units.</dd>
<dt>{{domxref("SVGSVGElement.createSVGTransform()")}}</dt>
<dd>Creates an {{domxref("SVGTransform")}} object outside of any document trees. The object is initialized to an identity matrix transform (<code>SVG_TRANSFORM_MATRIX</code>).</dd>
<dt>{{domxref("SVGSVGElement.createSVGTransformFromMatrix()")}}</dt>
<dd>Creates an {{domxref("SVGTransform")}} object outside of any document trees. The object is initialized to the given matrix transform (i.e., <code>SVG_TRANSFORM_MATRIX</code>). The values from the parameter matrix are copied, the matrix parameter is not adopted as <code>SVGTransform::matrix</code>.</dd>
<dt>{{domxref("SVGSVGElement.getElementById()")}}</dt>
<dd>Searches this SVG document fragment (i.e., the search is restricted to a subset of the document tree) for an Element whose id is given by <em>elementId</em>. If an Element is found, that Element is returned. If no such element exists, returns null. Behavior is not defined if more than one element has this id.</dd>
</dl>
<h2 id="Specifications">Specifications</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Specification</th>
<th scope="col">Status</th>
<th scope="col">Comment</th>
</tr>
<tr>
<td>{{SpecName("SVG2", "struct.html#InterfaceSVGSVGElement", "SVGSVGElement")}}</td>
<td>{{Spec2("SVG2")}}</td>
<td>Replaced the inheritance from {{domxref("SVGElement")}} by {{domxref("SVGGraphicsElement")}}, removed the implemented interfaces {{domxref("SVGTests")}}, {{domxref("SVGLangSpace")}}, {{domxref("SVGExternalResourcesRequired")}}, {{domxref("SVGStylable")}}, {{domxref("SVGLocatable")}}, {{domxref("DocumentEvent")}}, {{domxref("ViewCSS")}}, and {{domxref("DocumentCSS")}} and added implemented interface {{domxref("WindowEventHandlers")}}.</td>
</tr>
<tr>
<td>{{SpecName("SVG1.1", "struct.html#InterfaceSVGSVGElement", "SVGSVGElement")}}</td>
<td>{{Spec2("SVG1.1")}}</td>
<td>Initial definition</td>
</tr>
</tbody>
</table>
<h2 id="Browser_compatibility">Browser compatibility</h2>
<div class="hidden"><font><font>此页面上的兼容性表是根据结构化数据生成的。</font><font>如果您想为数据做出贡献,请查看</font></font><a href="https://github.com/mdn/browser-compat-data"><font><font>https://github.com/mdn/browser-compat-data</font></font></a><font><font>并向我们发送拉取请求。</font></font></div>
<p><font><font>{{COMPAT("api.SVGSVGElement")}}</font></font></p>
<h2 id="也可以看看"><font><font>也可以看看</font></font></h2>
<ul>
<li>{{SVGElement("circle")}}</li>
</ul>
|