-
-
Notifications
You must be signed in to change notification settings - Fork 392
WebIDL thing is not defined
Sid Vishnoi edited this page Jun 30, 2020
·
21 revisions
You probably landed here because you got a warning like:
- attribute
thing
not defined inSomeInterface
.
This is trying to tell you that you forgot to define this part of the interface. * Or that you forgot to explicitly define the interface itself!
Tl;dr:
- Add
data-dfn-for="SomeInterface"
data-link-for="SomeInterface"
to the container<section>
. - Change
SomeInterface
to the name of the Interface, Dictionary, or Enum you are defining. - Now use
<dfn>
to define the methods, attributes, or enum values.
Full example below...
Given:
<section>
<pre class="idl">
interface SomeInterface {
readonly attribute DOMString thing;
}
</pre
>
</section>
You want to add the following:
<!--
1. add data-dfn-for, and data-link-for to section,
with the name of the interface, dictionary, or enum
you are defining.
-->
<section data-dfn-for="SomeInterface" data-link-for="SomeInterface">
<!-- 2. explicitly define the interface: in the heading works best! -->
<h2><dfn>SomeInterface</dfn> interface</h2>
<pre class="idl">
interface SomeInterface {
readonly attribute DOMString thing;
OtherInterface someMethod();
}
</pre>
<!-- 3. Actually write something meaningful about the interface -->
<p>The <a>SomeInterface</a> lets you do really neat things!</p>
<!-- 4. define the `thing` attribute -->
<section>
<h3><dfn>thing</dfn> attribute</h3>
<p>The <a>thing</a> attribute, when getting, gives you the thing.</p>
</section>
<!-- 5. define the `someMethod()` attribute -->
<section>
<h3><dfn>someMethod()</dfn> attribute</h3>
<p>The <a>thing</a> attribute, when getting, gives you the thing.</p>
</section>
</section>
The above structure will give result in a nice structure for users. The ToC and links will all work as expected.
If the OtherInterface
interface is defined in a different spec, then all you need to do is link to it like this. Note that the code
element needs to surround the <dfn>
element:
<p>
The <code><dfn data-cite="SOME-SPEC#dom-SomeThing">OtherInterface</dfn></code>
interface is defined by [[!SOME-SPEC]].
</p>
💖 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