While reading over the WHATWG's HTML5 - A technical specification for Web developers I see many references such as:
Reflecting content attributes in IDL attributes
Some IDL attributes are defined to reflect a particular content attribute. This means that on getting, the IDL attribute returns the current value of the content attribute, and on setting, the IDL attribute changes the value of the content attribute to the given value.
and:
In conforming documents, there is only one body element. The document.body IDL attribute provides scripts with easy access to a document's body element.
The body element exposes as event handler content attributes a number of the event handlers of the Window object. It also mirrors their event handler IDL attributes.
My (admittedly fuzzy) understanding comes from the Windows world. I think an .idl file is used to map remote procedure calls in an n-tier distributed app. I would assume a content attribute refers to html element attributes.
There is no place in the standard that I can see that explains this usage of the terms "content attribute" and "IDL attribute". Could anyone explain what these terms mean and how the two kinds of attributes relate?
The IDL attribute is also known as a JavaScript property. These are the attributes you can read or set using JavaScript properties like element.
The HTML Living Standard (sometimes informally called HTML5). The HTML specification has been a living document without version numbers since 2011. It includes both HTML, the core markup language for the web, and a number of related APIs.
W3C HTML. https://html.spec.whatwg.org/multipage/ is the current HTML standard. It obsoletes all other previously-published HTML specifications.
The IDL (Interface Definition Language) comes from the Web IDL spec:
This document defines an interface definition language, Web IDL, that can be used to describe interfaces that are intended to be implemented in web browsers. Web IDL is an IDL variant with a number of features that allow the behavior of common script objects in the web platform to be specified more readily. How interfaces described with Web IDL correspond to constructs within ECMAScript execution environments is also detailed in this document.
Content attributes are the ones that appear in the markup:
<div id="mydiv" class="example"></div>
In the above code id
and class
are attributes. Usually a content attribute will have a corresponding IDL attribute.
For example, the following JavaScript:
document.getElementById('mydiv').className = 'example'
Is equivalent to setting the class
content attribute.
In JavaScript texts, the IDL attributes are often referred to as properties because they are exposed as properties of DOM objects to JavaScript.
While there's usually a corresponding pair of a content attribute and an IDL attribute/property, they are not necessarily interchangeable. For example, for an <option>
element:
selected
indicates the initial state of the option (and does not change when the user changes the option), selected
reflects the current state of the controlIf you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With