This document is also available in this non-normative format: Diff from previous Working Draft.
Copyright © 2010-2011 W3C® (MIT, ERCIM, Keio), All Rights Reserved. W3C liability, trademark and document use rules apply.
RDFa [RDFA-CORE] enables authors to publish structured information that is both human- and machine-readable. Concepts that have traditionally been difficult for machines to detect, like people, places, events, music, movies, and recipes, are now easily marked up in Web documents. While publishing this data is vital to the growth of Linked Data, using the information to improve the collective utility of the Web for humankind is the true goal. To accomplish this goal, it must be simple for Web developers to extract and utilize structured information from a Web document. This document details such a mechanism; an RDFa Application Programming Interface (RDFa API) that allows simple extraction and usage of structured information from a Web document.
This section is non-normative.
This document is a detailed specification for an RDFa API. The document is primarily intended for the following audiences:
For those looking for an introduction to the use of RDFa, or some real-world examples, please consult the RDFa Primer [RDFA-PRIMER].
If you are not familiar with RDF, you should read about the Resource Description Framework (RDF) [RDF-CONCEPTS] before reading this document. The [RDF-CONCEPTS] document outlines the core data model that is used by RDFa to express information.
If you are not familiar with RDFa, you should read and understand the [RDFA-CORE] specification. It describes how data is encoded in host languages using RDFa. A solid understanding of concepts in RDFa Core will inevitably help you understand how the RDFa API works in concert with how the data is expressed in a host language.
If you are not familiar with the RDF API, you should read about the Resource Description Framework Application Programming Interface [RDF-API] which is the base specification for this document. The [RDF-API] specification outlines fundamental programming concepts for working with Web-based data.
If you are a Web developer and are already familiar with RDF and RDFa, and you want to programatically extract RDFa content from documents, then you will find the Concept Diagram and Developing with the API sections of most interest. It contains a handful of ECMAScript examples on how to use the RDFa API.
Readers who are not familiar with the Terse RDF Triple Language [TURTLE] may want to read the specification in order to understand the short-hand RDF notation used in some of the examples.
This document uses the Web Interface Definition Language [WEBIDL] to specify all language bindings. If you intend to implement the RDFa API you should be familiar with the Web IDL language [WEBIDL].
Examples may contain references to existing vocabularies and use abbreviations in CURIEs and source code. The following is a list of all vocabularies and their abbreviations, as used in this document:
rdf, e.g., rdf:type)xsd, e.g., xsd:integer)rdfs, e.g., rdfs:label)foaf, e.g., foaf:name)As well as sections marked as non-normative, all authoring guidelines, diagrams, examples, and notes in this specification are non-normative. Everything else in this specification is normative.
The key words must, must not, required, should, should not, recommended, may, and optional in this specification are to be interpreted as described in [RFC2119].
Conformance requirements phrased as algorithms or specific steps may be implemented in any manner, so long as the end result is equivalent. In particular, the algorithms defined in this specification are intended to be easy to follow, and not intended to be performant.
User agents may impose implementation-specific limits on otherwise unconstrained inputs, e.g. to prevent denial of service attacks, to guard against running out of memory, or to work around platform-specific limitations.
Implementations that use ECMAScript or Java to implement the Interfaces defined in this specification must implement them in a manner consistent with the respective ECMAScript or Java Bindings defined in the Web IDL specification, as this specification uses that specification's terminology. [WEBIDL]
Implementations that use any other language to implement the Interfaces defined in this specification that do not have bindings defined in the Web IDL specification should attempt to map the Interfaces as closely as possible to the implementation language's native mechanisms and datatypes. Developers are encouraged to work with other developers who are providing the RDF Interfaces in the same langauge to ensure that implementations are modular and easily exchangable.
This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current W3C publications and the latest revision of this technical report can be found in the W3C technical reports index at http://www.w3.org/TR/.
The following changes have been made since the First Public Working Draft:
This document was published by the RDFa Working Group as a Working Draft. This document is intended to become a W3C Recommendation. If you wish to make comments regarding this document, please send them to public-rdfa-wg@w3.org (subscribe, archives). All feedback is welcome.
Publication as a Working Draft does not imply endorsement by the W3C Membership. This is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to cite this document as other than work in progress.
This document was produced by a group operating under the 5 February 2004 W3C Patent Policy. W3C maintains a public list of any patent disclosures made in connection with the deliverables of the group; that page also includes instructions for disclosing a patent. An individual who has actual knowledge of a patent which the individual believes contains Essential Claim(s) must disclose the information in accordance with section 6 of the W3C Patent Policy.
This section is non-normative.
RDFa provides a means to enable machine-readable markup of structured data in human-readable Web documents. Structured data that is contained in documents, such as people, films, companies, events, and so on, can provide an added layer of information to Web Applications. The RDFa API provides a set of interfaces that make it easy to access structured data in Web documents.
A document that contains RDFa effectively provides two data layers. The first layer is the information about the document itself, such as the relationship between the elements, the value of its attributes, the origin of the document, and so on, and this information is usually provided by the Document Object Model, or DOM [DOM-LEVEL-1].
The second data layer comprises information provided by embedded metadata, such as company names, film titles, ratings, and so on, and this is usually provided by RDFa [RDFA-CORE], Microformats [MICROFORMATS], DC-HTML, GRDDL, or Microdata.
Whilst this embedded information could be accessed via the usual DOM interfaces -- for example, by iterating through child elements and checking attribute values -- the potentially complex interrelationships between the data mean that it is more efficient for developers if they have direct access to the data after it has been extracted.
For example, a document may contain the name of a person in one section and the phone number of the same person in another; whilst the basic DOM interfaces provide access to these two pieces of information through normal navigation, it is more convenient for authors to have these two pieces of information available in one object.
This specification defines the RDFa API, which may be used by developers and Web Applications to access structured data contained in Web documents.
This section is non-normative.
RDFa 1.0 [RDFA-SYNTAX] has seen substantial growth since it became an official W3C Recommendation in October 2008. It has seen wide adoption among search companies, e-commerce sites, governments, and content management systems. There are numerous interoperable implementations and growth is expected to continue to rise with the latest releases of RDFa 1.1 [RDFA-CORE], XHTML+RDFa 1.1 [XHTML-RDFA], and HTML+RDFa 1.1 [HTML-RDFA].
In an effort to ensure that Web applications are able to fully utilize RDFa, this specification outlines an API and a set of interfaces that extract RDF data from Web documents and other document formats that utilize RDFa. The RDFa API is designed with maximum code expressiveness and ease of use in mind. Furthermore, a deep understanding of RDF and RDFa is not necessary in order to extract and utilize the structured data embedded in RDFa documents.
Since there are many Web browsers and programming environments for the Web, the rapid adoption of RDFa requires an interoperable API that Web document designers can count on being available in all Web browsers. The RDFa API provides a uniform and developer-friendly interface for extracting RDFa from Web documents.
Since most browser-based applications and browser extensions that utilize Web documents are written in ECMAScript [ECMA-262], the implementation of the RDFa API is primarily concerned with ensuring that concepts covered in this document are easily utilized in ECMAScript.
While ECMAScript is of primary concern, the RDFa API specification is language independent and is designed such that DOM tool developers may implement it in many of the other common Web programming languages such as Python, Java, Perl, and Ruby. Objects that are defined by the RDFa API are designed to work as seamlessly as possible with language-native types, operators, and program flow constructs.
The design goals that drove the creation of the APIs that are described in this document are:
document.getElementsBySubject(), which roughly mirrors the
document.getElementsByClassName() functionality that is a part of
[DOM-LEVEL-1].
The following diagram describes the relationship between all concepts discussed in this document.
 
Concept Stack for the RDFa API and RDF API
The RDFa API is layered on top of concepts defined by the RDF API. The lowest level concepts are Triples, Graphs and Projections. Triples, Graphs and Projections are data structures used by Web Developers to work with data expressed in RDF languages. Working directly with the data structures can be cumbersome at times, such as the requirement to use absolute URIs when accessing properties, thus Profiles are provided to support accessing the data using compact URIs (CURIEs). Data Parsers and Data Serializers provide mechanisms to both read and write RDF data in a variety of RDF languages. All of these concepts are provided via a high-level interface called the RDF Environment.
API implementers should note that only the portions of the RDF API that are directly used by this API need to be implemented for a conforming RDFa API implementation. That is, only Projections are required to be implemented from the RDF API for a fully conformant RDFa API implementation.
The higher-level RDFa API provides two interfaces for accessing data in the document. Simple queries for DOM data may be performed using the Document interface, while more complex queries for structured data may be performed using the Document Data interface.
This section is non-normative.
The following section provides an overview of the basic RDFa API that developers may find most useful in day-to-day programming exercises. An overview of the more advanced RDFa API is also provided, which may help developers when tackling some of the more complex RDFa programming tasks.
This section is non-normative.
This API provides a number of interfaces to enable:
Many web developers will find that the basic functionality provided by the RDFa API is sufficient for day-to-day programming tasks. Since developers typically work with object-oriented data structures, the basic API is geared toward building language-native objects called Projections and returning them to the developer.
document.data.getSubjects(optional property, optional value)document.data.getProperties(optional subject)document.data.getValues(optional subject, optional property)document.data.getProjection(subject, optional template)document.data.getProjection("http://example.com/people#bob").
    document.data.getProjections(optional property, optional value, optional template)foaf:name property, one could do the following:
     document.data.getProjections("foaf:name").
    document.getElementsByType(type)rdf:type expressed in the DOM Node. The type can be
      expressed via the typeof, rel, rev
      or the property attribute.
    document.getElementsBySubject(subject)about, href, 
      src, or resource attribute.
    document.getElementsByProperty(property, optional value)typeof, 
      rel, rev or property attribute.
    document.data.setMapping(mapping, iri)foaf to be mapped to a longer
       IRI, for example: http://xmlns.com/foaf/0.1/. This mapping
       ensures that when a developer specifies a compact URI like 
       foaf:Person, that it is expanded to
       http://xmlns.com/foaf/0.1/Person before it is used by the
       underlying API.document.data.rdfa.query(query, optional template)
The following section uses the markup shown below to demonstrate how to extract
and use subject, properties, values and Projections using the RDFa 
API. The following markup is used for the examples in this section and is 
assumed to be served from a document located at 
http://example.org/people.
<div prefix="foaf: http://xmlns.com/foaf/0.1/" about="#albert" typeof="foaf:Person"> <span property="foaf:name">Albert Einstein</span> </div>
Often, developers must determine whether or not a document contains the type of data that they are interested in processing. The RDFa API provides a simple mechanism to extract things like subjects, properties and values from the current document. The return types for subjects and properties are always sequences of strings. Values are typically converted into language-native types. Strings and language-native types are used in order to make processing the data easier on the developer.
For example to get all of the subjects expressed in a document, one can use the following call:var subjects = document.data.getSubjects();
To get the list of properties for each subject retrieved above, a developer could process each subject in a loop, like so:
for(var i = 0; i < subjects.length; i++)
{
   var subject = subjects[i];
   var properties = document.data.getProperties(subject);
   // ... process the properties ...
}
To retrieve only subjects containing a particular property, such as a name property, a developer could do the following:
var subjectsWithNames = document.data.getSubjects("http://xmlns.com/0.1/foaf/name");
Once the subjects containing a particular property are known, queries can be done on each subject to retrieve the values of properties:
var namedSubject = subjectsWithNames[0]; var names = document.data.getValues(namedSubject, "http://xmlns.com/0.1/foaf/name");
To retrieve all values for a particular property, such as all of the names listed in the document, the following code could be executed:
var allNames = document.data.getValues(null, "http://xmlns.com/0.1/foaf/name");
There are many more combinations of arguments passed to the basic getter methods for subjects, properties and values that allow high-level querying of data in the document. While this method of working with data may be useful to many developers, others may want to construct this data into a more object-oriented view of the data. In order to support this scenario, the RDFa API introduces Projections in the next section.
A Projection is an object-oriented view of a particular subject that is expressed in the document. For example, to get all projections that express people in a document, a developer can do the following:
var people = document.data.getProjections("http://www.w3.org/1999/02/22-rdf-syntax-ns#type", "http://xmlns.com/foaf/0.1/Person");
A developer can also specify short-cuts to use when specifying the URI:
document.data.setMapping("rdf", "http://www.w3.org/1999/02/22-rdf-syntax-ns#type");
document.data.setMapping("foaf", "http://xmlns.com/foaf/0.1/");
var people = document.data.getProjections("rdf:type", "foaf:Person");
You can also get a Projection by its subject:
var albert = document.data.getProjection("http://example.org/people#albert");
You can also specify a relative IRI and the document IRI will be automatically pre-pended:
var albert = document.data.getProjection("#albert");
You can get a list of Projections by their properties:
var peopleNamedAlbert = document.data.getProjections("foaf:name", "Albert Einstein");
You can retrieve property values from Projections like so:
var albert = document.data.getProjection("#albert");
var name = albert.get("foaf:name");
You can specify values that you would like to map to a Projection:
var albert = document.data.getProjection("#albert", {"name": "foaf:name"});
var name = albert.name;
You can retrieve the DOM Element that is described above by doing the following:
var elements = document.getElementsByType("http://xmlns.com/foaf/0.1/Person");
or you can specify a short-cut to use when specifying the IRI:
document.data.setMapping("foaf", "http://xmlns.com/foaf/0.1/");
var elements = document.getElementsByType("foaf:Person");
You can also get a list of Elements by the subject of the data:
var elements = document.getElementsBySubject("http://example.org/people#albert");
You can also specify a relative IRI and the document IRI will be automatically pre-pended:
var elements = document.getElementsBySubject("#albert");
You can get a list of Elements by the properties and values that they declare:
var elements = document.getElementsByProperty("foaf:name", "Albert Einstein");
You can modify elements that are returned just like any other DOM Node, for example:
var elements = document.getElementsByProperty("foaf:name", "Bob");
for(i = 0; i <= elements.length; i++)
{
   var e = elements[i];
   e.style.setProperty('color', '#00cc00', null);
}
The code above would change the color of all the areas of the page where the item's name is "Bob" to green.
This section covers a number of concepts that go beyond basic day-to-day usage of the RDFa API.
Perhaps the most basic task is to select Projections of a
particular type. The type of a Projection is set in RDFa via
the special attribute typeof. For example, the following
markup expresses a Projection of type Person in the
Friend-of-a-Friend vocabulary:
<div typeof="foaf:Person"> <span property="foaf:name">Albert Einstein</span> </div>
To locate all Projections that are people, we could use the
document.getProjections() method:
document.data.getProjections("rdf:type", "foaf:Person");
or we could do the same using the standard query interface to retrieve a
Projection:
var people = document.data.rdfa.query({"rdf:type": "foaf:Person"}, 
   {"name": "foaf:name", "age": "foaf:age"});
While the query interface is more verbose for simple queries, it becomes necessary for more complex queries as demonstrated later in this section. Note that the Query object has access to the mappings provided via the document.data object, so they can also be used in queries. It is also possible to write the same query in a way that is independent of any prefix-mappings:
var people = document.data.rdfa.query( 
   { "http://www.w3.org/1999/02/22-rdf-syntax-ns#type": "http://xmlns.com/foaf/0.1/Person" },
   { "name": "http://xmlns.com/foaf/0.1/name", "age": "http://xmlns.com/foaf/0.1/age" });
The previous query selected all Projections of a certain
type, but it did so by indicating that the property rdf:type
should have a specific value. Queries can also specify other
properties. For example, given the following mark-up:
<div typeof="foaf:Person"> <span property="foaf:name">Albert Einstein</span> - <span property="foaf:myersBriggs">INTP</span> <a rel="foaf:workInfoHomepage" href="http://en.wikipedia.org/wiki/Albert_Einstein">More...</span> </div> <div typeof="foaf:Person"> <span property="foaf:name">Mother Teresa</span> - <span property="foaf:myersBriggs">ISFJ</span> <a rel="foaf:workInfoHomepage" href="http://en.wikipedia.org/wiki/Mother_Teresa">More...</span> </div> <div typeof="foaf:Person"> <span property="foaf:name">Marie Curie</span> - <span property="foaf:myersBriggs">INTP</span> <a rel="foaf:workInfoHomepage" href="http://en.wikipedia.org/wiki/Marie_Curie">More...</span> </div>
The following query demonstrates how a developer would select and use all Projections of type Person that also have a Myers Brigg's personality type of "INTP" (aka: The Architect):
var architects = document.data.rdfa.query({
  "http://www.w3.org/1999/02/22-rdf-syntax-ns#type": "http://xmlns.com/foaf/0.1/Person",
  "http://xmlns.com/foaf/0.1/myersBriggs": "INTP" },
  { "name": "http://xmlns.com/foaf/0.1/name" });
var name = architects[0].name;
As before, prefix-mappings can also be used:
var architects = document.data.rdfa.query( 
   { "rdf:type": "foaf:Person", "foaf:myersBriggs": "INTP" },
   { "name": "foaf:name" });
var name = architects[0].name;
In this case, all of the "INTP" personality types are gleaned from the 
page and presented as Projections containing each person's 
name and blog page:
var architects = document.data.rdfa.query( 
   { "rdf:type": "foaf:Person", "foaf:myersBriggs": "INTP" },
   { "name": "foaf:name", "webpage": "foaf:workInfoHomepage" });
var name = architects[0].name;
var infoWebpage = architects[0].webpage;
There has been a complaint that this section comes from out of nowhere. The purpose of this section is to describe that Projections can be mapped to native language objects to ease development. We may need to elaborate more on this at this point in the document to help integrate this section with the flow of the document.
For example, assume our source document contains the following event, marked up using the Data Vocabulary Event format:
<div prefix="v: http://rdf.data-vocabulary.org/#" typeof="v:Event"> 
  <a rel="v:url" href="http://amyandtheredfoxies.example.com/events" 
     property="v:summary">Tour Info: Amy And The Red Foxies</a>
  
  <span rel="v:location">
  	<a typeof="v:Organization" rel="v:url" href="http://www.kammgarn.de/" property="v:name">Kammgarn</a>
  </span>
  <div rel="v:photo"><img src="foxies.jpg"/></div>
  <span property="v:summary">Hey K-Town, Amy And The Red Foxies will rock Kammgarn in October.</span>
  When: 
  <span property="v:startDate" content="20091015T19:00">15. Oct., 7:00 pm</span>-
  <span property="v:endDate" content="20091015T21:00">9:00 pm</span>
  </span>
  Category: <span property="v:eventType">concert</span>
</div>
To query for all Event Projections we know that we can do this:
var events = document.data.getProjections("rdf:type", "http://rdf.data-vocabulary.org/#Event");
However, to build a special Projection that contains the summary, start date and end date, we can also do this:
var events = document.data.rdfa.query(
   { "rdf:type": "http://rdf.data-vocabulary.org/#Event" },
   { "type": "rdf:type", "summary": "v:summary", 
     "start": "v:startDate", "end": "v:endDate" } );
The second parameter is a Projection Template. Each key-value pair specifies a Projection property to URI mapping. That is, the key is the name of the property to create in the Projection object. The value must exist in a triple, specifically as a property of the triple, in order to copy the the object value of the triple over to the value of the Projection object's property.
For more detailed information about queries and Projections see the 
DocumentData interface.
The following section contains all of the interfaces that RDFa API implementers are expected to provide as well as guidance to ensure that implementations are conformant.
Conformance requirements phrased as algorithms or specific steps may be implemented in any manner, so long as the end result is equivalent. In particular, the algorithms defined in this specification are intended to be easy to follow and are not necessarily intended to be performant.
User Agents may impose implementation-specific limits on otherwise unconstrained inputs, e.g. to prevent denial of service attacks, to guard against running out of memory, or to work around platform-specific limitations.
Implementations that use ECMAScript or Java to implement the APIs defined in this specification must implement them in a manner consistent with the respective ECMAScript or Java Bindings defined in the Web IDL specification [WEBIDL], as this specification uses that specification's terminology.
Implementations that use any other language to implement the APIs defined in this specification that do not have bindings defined in the Web IDL specification should attempt to map the API as closely as possible to the implementation language's native mechanisms and datatypes. Developers are encouraged to work with other developers who are providing the RDFa API in the same langauge to ensure that RDFa API implementations are modular and easily replaceable.
The Projection interface is used to build language-native objects that can be accessed in a way that is natural for the implementation language.
[NoInterfaceObject]
interface Projection {
    DOMString[] getProperties ();
    DOMString   getSubject ();
    any getter  get (in DOMString uriOrCurie);
    any[]       getAll (in DOMString uriOrCurie);
};
get| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| uriOrCurie | DOMString | ✘ | ✘ | The name of the property to retrieve. The argument can be either an absolute URI or a CURIE that will be resolved using the default document mapping. | 
any gettergetAll| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| uriOrCurie | DOMString | ✘ | ✘ | The name of the property to retrieve. The argument can be either a full URI or a CURIE that will be resolved using the default document mapping. | 
any[]getPropertiesDOMString[]getSubjectDOMStringThe RDFa API is designed to provide a small, powerful set of document-based interfaces that a developer may use to retrieve Projections from a Web document. This section focuses on the extensions necessary to the DOM environment. These extensions are separated into four interfaces:
The following section describes all of the extensions that are necessary to enable manipulation of structured data within a Web Document.
Document implements DataDocument;DataDocument.
The DataDocument interface provides necessary extensions to the core DOM Document interface to enable the processing and storage of structured data.
[Supplemental, NoInterfaceObject]
interface DataDocument {
    readonly attribute DocumentData data;
    NodeList getElementsByType (in DOMString type);
    NodeList getElementsBySubject (in DOMString subject);
    NodeList getElementsByProperty (in DOMString property, in optional DOMString? value);
};
data of type DocumentData, readonlyDocumentData interface is useful for extracting and storing data
     that is associated with the Document.getElementsByProperty| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| property | DOMString | ✘ | ✘ | A DOMString representing an IRI-based property. The string can either be a absolute URI or a CURIE. | 
| value | DOMString | ✔ | ✔ | A DOMString representing the value to match against. | 
NodeListgetElementsBySubject| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| subject | DOMString | ✘ | ✘ | A DOMString representing an IRI-based subject. The string can either be a absolute URI or a CURIE. | 
NodeListgetElementsByType| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| type | DOMString | ✘ | ✘ | A DOMString representing an rdf:typeto select against. | 
NodeList
If the RDFa API is implemented in a DOM environment and a 
DOMImplementation interface is provided, the following
additional requirements for the hasFeature() method must be
met:
interface DOMImplementation {
    boolean hasFeature (in DOMString feature, in DOMString version);
};
hasFeaturetrue for a feature string of
    "RDFaAPI" and a version string of "1.1".
  
  
  | Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| feature | DOMString | ✘ | ✘ | The feature string to use when checking to see if the DOM environment exposes all of the RDFa API attributes and methods. | 
| version | DOMString | ✘ | ✘ | The version string to use when checking to see if the DOM environment exposes all of the RDFa API attributes and methods. | 
boolean
The DocumentData interface is used to access the structured data
in the document.
[NoInterfaceObject]
interface DocumentData {
    attribute optional RDFEnvironment rdf;
    attribute RDFaEnvironment         rdfa;
    Projection            getProjection (in DOMString subject, in optional object template);
    Sequence rdf of type optional RDFEnvironmentrdfa of type RDFaEnvironmentgetProjectionnull is returned.
  
  | Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| subject | DOMString | ✘ | ✘ | The subject to use when matching against triples. The subject can
    be either an absolute URI or a CURIE. The subject is used
    to match against the URI in the first part of a triple. An implementation 
    must coerce the DOMString to the same type as the triple's subject being 
    compared. If the type coercion will result in a URI, the CURIE mappings 
    must be queried first for a mapping and the given property expanded as a 
    CURIE if a mapping is found. If the subject does not exist in the 
    document, the return value must be null. | 
| template | object | ✘ | ✔ | The Projection template is used to build the return value. The template consists of a key-value associative array where the key is the name of the property to create in the Projection and the value is the URI to use when matching against predicates in each triple. | 
ProjectiongetProjections| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| template | object | ✘ | ✔ | The Projection template is used to build the return value. The template consists of a key-value associative array where the key is the name of the property to create in the Projection and the value is the URI to use when matching against predicates in each triple. | 
Sequence <Projection>getProjections| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| property | DOMString | ✘ | ✔ | The property to use when matching against triples. The property can
    be either an absolute URI or a CURIE. The property is used
    to match against the URI in the second part of a triple, also known as the
    predicate. An implementation must coerce the DOMString to the same type as
    the predicate being compared. If the type coercion will result in
    a URI, the CURIE mappings must be queried first for a mapping and the given 
    property expanded as a CURIE if a mapping is found. If the value is null, the match is always positive. | 
| value | DOMString | ✔ | ✔ | The value to use when matching against triples. The value can
    be either an absolute URI or a CURIE. The value is used to 
    match against the final part of a triple, also known as the object. An 
    implementation must coerce the DOMString to the same type as the 
    object being compared. If the type coercion will result in a URI, the 
    CURIE mappings must be queried first for a mapping and the given value 
    expanded as a CURIE if a mapping is found. If the value is null, the match is always positive. | 
| template | object | ✘ | ✔ | The Projection template is used to build the return value. The template consists of a key-value associative array where the key is the name of the property to create in the Projection and the value is the URI to use when matching against predicates in each triple. | 
Sequence <Projection>getProperties| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| subject | DOMString | ✔ | ✔ | The subject to use when matching against triples. The subject is used
    to match against the URI in the first part of a triple. The subject can
    be either an absolute URI or a CURIE. The subject is used to 
    match against the first part of a triple. An implementation must coerce the 
    DOMString to the same type as the triple's subject that is being compared. 
    If the type coercion will result in a URI, the CURIE mappings must be 
    queried first for a mapping and the given property expanded as a CURIE if a 
    mapping is found. If the given subject is null, the match is 
    always positive. | 
Sequence<DOMString>getSubjects| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| property | DOMString | ✔ | ✔ | The property to use when matching against triples. The property can
    be either an absolute URI or a CURIE. The property is used
    to match against the URI in the second part of a triple, also known as the
    predicate. An implementation must coerce the DOMString to the same type as
    the predicate being compared. If the type coercion will result in
    a URI, the CURIE mappings must be queried first for a mapping and the given 
    property expanded as a CURIE if a mapping is found. If the value is null, the match is always positive. | 
| value | DOMString | ✔ | ✔ | The value to use when matching against triples. The value can
    be a number, a boolean, a DOMString, an absolute URI or a CURIE. The value is 
    used to match against the final part of a triple, also known as the object. 
    An implementation must coerce the DOMString to the same type as the triple
    object being compared. If the type coercion will result in a URI, the 
    CURIE mappings must be queried first for a mapping and the given property 
    expanded as a CURIE if a mapping is found. If the value is null, the match is always positive. | 
Sequence<DOMString>getValues| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| subject | DOMString | ✔ | ✔ | The subject to use when matching against triples. The subject can
    be either an absolute URI or a CURIE. The subject is used
    to match against the URI in the first part of a triple. An implementation 
    must coerce the DOMString to the same type as the subject being 
    compared. If the type coercion will result in a URI, the CURIE mappings must 
    be queried first for a mapping and the given property expanded as a CURIE if 
    a mapping is found. If the value is null, the match is always 
    positive. | 
| property | DOMString | ✔ | ✔ | The property to use when matching against triples. The property can
    be either an absolute URI or a CURIE. The property is used
    to match against the URI in the second part of a triple, also known as the
    predicate. An implementation must coerce the DOMString to the same type as
    the predicate being compared. If the type coercion will result in
    a URI, the CURIE mappings must be queried first for a mapping and the given 
    property expanded as a CURIE if a mapping is found. If the value is null, the match is always positive. | 
Sequence<any>setMapping| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| mapping | in DOMString | ✘ | ✘ | The shortened form of the URI to map. | 
| uri | in DOMString | ✘ | ✘ | An absolute URI that the mapping should expand to when used with any of the structured data APIs. | 
DOMStringThe RDFaEnvironment interface is used to perform RDFa-specific actions.
[NoInterfaceObject]
interface RDFaEnvironment {
    Sequencequery| Parameter | Type | Nullable | Optional | Description | 
|---|---|---|---|---|
| query | object | ✔ | ✔ | An associative array containing properties as keys and strings to match as values. If the query is null, every item in the default storage mechanism is returned. | 
| template | object | ✘ | ✔ | A template describing the attributes to create in each Projection that is returned. The template is an associative array containing key-value pairs. Each key corresponds to a property that will be created in the Projection that is returned. Each value corresponds to a triple's property, also known as a predicate, whose value will be stored in the Projection as the value of the key specified in the template. | 
Sequence<Projection>The RDFa API must be initialized before the Web developer has access to any of the methods that are defined in this specification. To initialize the API environment in a Browser-based environment, an implementor must do the following:
window.location.toString().
This section is non-normative.
The RDFa Working Group is currently discussing whether or not to include the following advanced functionality:
At the time of publication, the members of the RDFa Working Group were: