aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/api/htmlaudioelement/index.html
blob: 858a4e7542cc4dafa37c2ce70008ea25af616de5 (plain)
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
---
title: HTMLAudioElement
slug: Web/API/HTMLAudioElement
translation_of: Web/API/HTMLAudioElement
---
<div>{{APIRef("HTML DOM")}}</div>

<p><span class="seoSummary"><strong><code>HTMLAudioElement</code></strong> 接口提供对 {{HTMLElement("audio")}} 元素的属性访问及一系列操控它的方法,</span>它基于并从 {{domxref("HTMLMediaElement")}} 接口继承属性和方法。</p>

<p>{{InheritanceDiagram(600, 120)}}</p>

<h2 id="构造函数">构造函数</h2>

<dl>
 <dt>{{domxref("HTMLAudioElement.Audio", "Audio()")}}</dt>
 <dd>创建并返回一个新的 <code>HTMLAudioElement</code> 对象,如果提供音频文件 URL,则开始加载音频文件。</dd>
</dl>

<h2 id="属性">属性</h2>

<p><em>没有具体的属性;从父类 {{domxref("HTMLMediaElement")}} 和 {{domxref("HTMLElement")}} 继承属性。</em></p>

<h2 id="方法">方法</h2>

<p><em>从父类 {{domxref("HTMLMediaElement")}} 和 {{domxref("HTMLElement")}} 继承方法,自身不提供方法。</em></p>

<h3 id="废弃的且仅适用于_Mozilla_的方法">废弃的且仅适用于 Mozilla 的方法</h3>

<p><em>以下方法是未标准化的,请勿使用.</em></p>

<dl>
 <dt>{{domxref("HTMLAudioElement.mozCurrentSampleOffset", "mozCurrentSampleOffset()")}} {{non-standard_inline}} {{obsolete_inline}}</dt>
 <dd>Returns the number of samples form the beginning of the stream that have been written so far into the audio stream created by calling {{domxref("HTMLAudioElement.mozWriteAudio", "mozWriteAudio()")}}.</dd>
 <dt>{{domxref("HTMLAudioElement.mozSetup", "mozSetup()")}} {{non-standard_inline}} {{obsolete_inline}}</dt>
 <dd>Sets up the audio stream to allow writing, given the number of audio channels (1 or 2) and the sample rate in kHz.</dd>
 <dt>{{domxref("HTMLAudioElement.mozWriteAudio", "mozWriteAudio()")}} {{non-standard_inline}} {{obsolete_inline}}</dt>
 <dd>Writes a batch of audio frames to the stream at the current offset, returning the number of bytes actually written to the stream.</dd>
</dl>

<h2 id="示例">示例</h2>

<h3 id="基本用法">基本用法</h3>

<p>你可以完全使用 JavaScript 的 {{domxref("HTMLAudioElement.Audio", "Audio()")}} 构造函数来创建一个 <code>HTMLAudioElement</code> :</p>

<pre class="brush: js notranslate">var audioElement = new Audio('car_horn.wav');
</pre>

<p>然后你可以在这个元素上调用 <code>play()</code> 方法</p>

<pre class="brush: js notranslate">audioElement.play();</pre>

<div class="note">
<p>一个常见的需求是在页面加载后马上去播放音频,现代浏览器的默认自动播放策略会阻止这一行为,参见 <a href="https://hacks.mozilla.org/2019/02/firefox-66-to-block-automatically-playing-audible-video-and-audio/">firefox</a> 和 <a href="https://developers.google.com/web/updates/2017/09/autoplay-policy-changes">chrome</a> 寻找最佳实践和解决方案。</p>
</div>

<p>一些经常被使用的属性,包括 {{domxref("HTMLMediaElement.src", "src")}}{{domxref("HTMLMediaElement.currentTime", "currentTime")}}{{domxref("HTMLMediaElement.duration", "duration")}}{{domxref("HTMLMediaElement.paused", "paused")}}{{domxref("HTMLMediaElement.muted", "muted")}} 和 {{domxref("HTMLMediaElement.volume", "volume")}}。以下这段代码赋值音频文件的播放时长给一个变量:</p>

<pre class="brush: js notranslate">var audioElement = new Audio('car_horn.wav');
audioElement.addEventListener('loadeddata', () =&gt; {
  let duration = audioElement.duration;
  // duration 变量现在存放音频的播放时长(单位秒)
})</pre>

<dl>
</dl>

<h2 id="事件">事件</h2>

<p><em>从父类 {{domxref("HTMLMediaElement")}} 和祖先 {{domxref("HTMLElement")}} 继承方法. 使用 </em><code><a href="https://developer.mozilla.org/zh-CN/docs/Web/API/EventTarget/addEventListener">addEventListener()</a></code> <em>监听事件或者赋值一个事件监听器给这个接口的 </em><code>on<em>eventname</em></code> 属性。</p>

<h2 id="规范">规范</h2>

<table class="standard-table">
 <thead>
  <tr>
   <th scope="col">Specification</th>
   <th scope="col">Status</th>
   <th scope="col">Comment</th>
  </tr>
 </thead>
 <tbody>
  <tr>
   <td>{{SpecName('HTML WHATWG', "#htmlaudioelement", "HTMLAudioElement")}}</td>
   <td>{{Spec2('HTML WHATWG')}}</td>
   <td></td>
  </tr>
  <tr>
   <td>{{SpecName('HTML5 W3C', "embedded-content-0.html#the-audio-element", "HTMLAudioElement")}}</td>
   <td>{{Spec2('HTML5 W3C')}}</td>
   <td></td>
  </tr>
 </tbody>
</table>

<h2 id="浏览器兼容性">浏览器兼容性</h2>



<p>{{Compat("api.HTMLAudioElement")}}</p>

<h2 id="参见">参见</h2>

<ul>
 <li><a href="/zh-CN/docs/Web/Media">Web media technologies</a></li>
 <li><a href="/zh-CN/docs/Web/Media/HTML_media">Using audio and video in HTML</a></li>
 <li>HTML element implementing this interface: {{HTMLElement("audio")}}.</li>
</ul>