-
-
Notifications
You must be signed in to change notification settings - Fork 392
WebIDL Guide
To specify an interface using WebIDL, you define a <pre class="idl">
block.
<pre class="idl">
interface Request {
readonly attribute ByteString method;
readonly attribute USVString url;
};
</pre>
The recommended way to code up your WebIDL is as follows:
<section data-dfn-for="ExampleInterface">
<h2><dfn>ExampleInterface</dfn> interface</h2>
<pre class="idl">
interface ExampleInterface {
void exampleMethod();
readonly attribute USVString url;
};
</pre>
<section>
<h2><dfn>exampleMethod()</dfn> method</h2>
<p>The {{ExampleInterface/exampleMethod()}} method steps are:</p>
<ol class="algorithm">
<li>Let |x| be ...</li>
</ol>
</section>
<section>
<h2><dfn>url</dfn> attribute</h2>
<p>The {{ExampleInterface/url}} attribute...</p>
</section>
</section>
<section>
<h2>Here is how you link!</h2>
<p>
The {{ExampleInterface}}
or the {{ExampleInterface/exampleMethod()}} method
or the {{ExampleInterface/url}} attribute.
</p>
</section>
Given interface Request {};
, you can define the interface inside a heading like so:
<section>
<h2><dfn>Request</dfn> interface</h2>
<pre class="idl">
interface Request {};
</pre>
<p>An instance of {{Request}} allows you to make a request.</p>
</section>
The above provides convenient linking to the section where the interface is defined.
When defining things, the data-dfn-for
creates child-parent relationships (e.g., a .method()
is "for", or part of, SomeInterface
).
For example, the following defines both the url
and the clone
method.
<section data-dfn-for="Request">
<h2>`Request` interface</h2>
<pre>
interface Request {
readonly attribute ByteString method;
readonly attribute USVString url;
};
</pre>
<p>The <dfn>clone()</dfn> method. The <dfn>url</dfn> attribute.</p>
<p>
Links to {{Request/clone()}} method. Links to the {{Request/url}} attribute.
</p>
</section>
If, for instance, you have two interfaces with methods or attributes that are the same:
<pre class="idl">
interface Request {
readonly attribute USVString url;
};
interface Response {
readonly attribute USVString url;
};
</pre>
You explicitly distinguish between them like so:
<section data-dfn-for="Request">
<p>
The <dfn>url</dfn> attribute of {{Request}} is used by {{Response/url}}.
</p>
</section>
<section data-dfn-for="Response">
<p>
The <dfn>url</dfn> attribute of {{Response}} depends on {{Request/url}}.
</p>
</section>
💖 Support ReSpec by becoming a sponsor via Open Collective. 💖
✨ View rendered version of this documentation at https://respec.org/docs/ ✨
- addSectionLinks
- authors
- caniuse
- edDraftURI
- editors
- favicon
- format (markdown)
- formerEditors
- github
- highlightVars
- isPreview
- license
- lint
- localBiblio
- logos
- maxTocLevel
- mdn
- modificationDate
- noTOC
- otherLinks
- pluralize
- postProcess
- preProcess
- previousDiffURI
- previousMaturity
- previousPublishDate
- prevRecShortname
- prevRecURI
-
processVersion(Deprecated) - publishDate
-
refNote(Deprecated) - shortName
- specStatus
- subjectPrefix
- subtitle
- testSuiteURI
- xref
- additionalCopyrightHolders
-
addPatentNote(Deprecated) - alternateFormats
- canonicalURI
- charterDisclosureURI
- copyrightStart
- crEnd
-
darkMode(deprecated, use dark mode) - doJsonLd
- errata
- group
- implementationReportURI
- lcEnd
- level
- noRecTrack
- prevED
- submissionCommentNumber
-
wg(Deprecated) -
wgId(Deprecated) -
wgPatentPolicy(Deprecated) -
wgPatentURI(Deprecated) - wgPublicList
-
wgURI(Deprecated)
a11y
check-punctuation
local-refs-exist
no-headingless-sections
no-http-props
no-unused-vars
no-unused-dfns
informative-dfn
privsec-section
wpt-tests-exist
Handled by ReSpec for you.
- data-abbr
-
data-cite(Not recommended) - data-dfn-for
- data-dfn-type
- data-format
- data-include-format
- data-include-replace
- data-include
- data-link-for
- data-link-type
- data-local-lt
- data-lt-no-plural
- data-lt-noDefault
- data-lt
- data-number
- data-oninclude
- data-sort
- data-tests
-
data-transform(Deprecated) - data-type
- dir
- lang