XML namespace: Difference between revisions

Content deleted Content added
No edit summary
Rescuing 1 sources and tagging 0 as dead.) #IABot (v2.0.9.5
 
(39 intermediate revisions by 34 users not shown)
Line 1:
{{short description|Method of providing unique elements and attributes in an XML document}}
'''XML namespaces''' are used for providing uniquely named [[Data element|elements]] and attributes in an [[XML]] document. They are defined in a [[W3C]]World [[Wide Web Consortium|W3C recommendation|recommendation]].<ref>{{cite web|last=Bray|first=Tim|title=Namespaces in XML 1.0|url=http://www.w3.org/TR/xml-names/|publisher=[[W3C]]|accessdateaccess-date=9 October 2010|coauthorsauthor2=Dave Hollander, |author3=Andrew Layman, |author4=Richard Tobin, |author5=Henry S. Thompson |date=December 2009}}</ref><ref name="timelinehistory">{{cite web |url=http://www.dblab.ntua.gr/~bikakis/XML%20and%20Semantic%20Web%20W3C%20Standards%20Timeline-HistoryXMLSemanticWebW3CTimeline1.2.pdf |title=XML and Semantic Web W3C Standards Timeline (v.1.2) |access-date=2022-04-02 |archive-date=2022-12-29 |archive-url=https://web.archive.org/web/20221229130856/http://www.dblab.ntua.gr/~bikakis/XMLSemanticWebW3CTimeline1.2.pdf |url-status=dead }}</ref> An XML instance may contain element or attribute names from more than one XML vocabulary. If each vocabulary is given a [[namespace]], the ambiguity between identically named elements or attributes can be resolved.
 
A simple example would be to consider an XML instance that contained references to a customer and an ordered product. Both the customer element and the product element could have a child element named '''id'''. References to the '''id''' element would therefore be ambiguous; placing them in different namespaces would remove the ambiguity.
Line 9 ⟶ 10:
Although the term ''namespace URI'' is widespread, the W3C Recommendation refers to it as the ''namespace name''. The specification is not entirely prescriptive about the precise rules for namespace names (it does not explicitly say that parsers must reject documents where the namespace name is not a valid [[Uniform Resource Identifier]]), and many XML parsers allow any character string to be used. In version 1.1 of the recommendation, the namespace name becomes an [[Internationalized Resource Identifier]], which licenses the use of non-ASCII characters that in practice were already accepted by nearly all XML software. The term ''namespace URI'' persists, however, not only in popular usage, but also in many other specifications from W3C and elsewhere.
 
Following publication of the Namespaces recommendation, there was an intensive debate about how a relative URI should be handled, with some intensely arguing that it should simply be treated as a character string, and others arguing with conviction that it should be turned into an absolute URI by resolving it against the base URI of the document.<ref>{{cite web|title=News from the trenches|first=Leigh|last=Dodds|date=24 May 2000|url=httphttps://www.xml.com/pub/a/2000/05/24/deviant/index.html |publisher=O'Reilly Media, Inc.}}</ref> The result of the debate was a ruling from W3C that relative URIs were deprecated.<ref>{{citecitation|title=W3C XML Plenary decision on relative URI references in namespace declarations|first=Dan|last=Connolly|date=11 Sep 2000}}</ref>
 
The use of URIs taking the form of URLs in the http scheme (such as ''http://www.w3.org/1999/xhtml'') is common, despite the absence of any formal relationship with the HTTP protocol. The Namespaces specification does not say what should happen if such a URL is dereferenced (that is, if software attempts to retrieve a document from this ___location). One convention adopted by some users is to place an [[RDDL]] document at the ___location.<ref>{{citeCite web|first=Elliotte Rusty|last=Harold|title=RDDL Me This: What Does a Namespace URL Locate?|date=20 Feb 2001|url=http://www.oreillynet.com/pub/a/oreilly/xml/news/xmlnut2_0201.html|archive-url=https://web.archive.org/web/20170507150520/http://archive.oreilly.com/pub/a/oreilly/xml/news/xmlnut2_0201.html|archive-date=7 May 2017}}</ref> In general, however, users should assume that the namespace URI is simply a name, not the address of a document on the Web.
 
== Namespace declaration ==
Line 27 ⟶ 28:
 
In this case, any element without a namespace prefix is considered to be in the XHTML namespace, if it or an ancestor has the above default namespace declaration.
 
If there is no default namespace declaration in scope, the namespace name has no value.<ref>{{cite web|url=https://www.w3.org/TR/REC-xml-names/#dt-qualname|title=Namespaces in XML 1.0 (Third Edition)|publisher=W3C|access-date=28 April 2017}}</ref> In that case, an element without an explicit namespace prefix is considered not to be in any namespace.
 
Attributes are never subject to the default namespace. An attribute without an explicit namespace prefix is considered not to be in any namespace.
 
== Namespaces in APIs and XML object models ==
== Namespace undeclaration ==
 
When an element carries the attribute <
 
XML Namespaces 1.1 also introduces the option to undeclare other namespace
 
== Namespaces in APIs and XML object models ==
 
Different specifications have taken different approaches on how namespace information is presented to applications.
 
Nearly all programming models allow the name of an element or attribute node to be retrieved as a three-part name: the local name, the namespace prefix, and the namespace URI. Applications should avoid attaching any significance to the choice of prefix, but the information is provided because it can be helpful to human readers. Names are considered equal, if the namespace URI and local name match.
 
In addition, most models provide some way of determining which namespaces have been declared for a given element. This information is needed because some XML vocabularies allow qualified names (containing namespace prefixes) to appear in the content of elements or attributes, as well as in their names. There are three main ways this information can be provided:
 
* As attribute nodes named "xmlns" or "xmlns:xxx", exactly as the namespaces are written in the source XML document. This is the model presented by [[Document Object Model|DOM]].
 
* As namespace declarations: distinguished from attributes, but corresponding one-to-one with the relevant attributes in the source XML document. This is the model presented by [[JDOM]].
 
* As in-scope namespace bindings: in this model, the application is able to determine which namespaces are in scope for any given element, but is not able to determine which elements contain the actual declarations. This is the model used in [[XPath]], [[XSLT]], and [[XQuery]].
 
Line 63 ⟶ 58:
{{W3C standards}}
 
<!--Interwikies-->
 
{{DEFAULTSORT:Xml Namespace}}
<!--Categories-->
{{DEFAULTSORT:Xml Namespace}}
[[Category:XML]]
 
<!--Interwikies-->
 
[[ja:Extensible Markup Language#XML名前空間]]