I understand that within a XML if I have same tagName for two different tags, then to separate the two of them, we precede it with the namespace to make it unique. but in the top when we say
<rootElement xmlns:myNameSpace="http://www.myNameSpace.com">
Now, why do we have this http://www.myNameSpace.com? What purpose does this serve, apart from the fact that it will be unique.
Also, I was reading about xslt, and since it is also a XML then it defined the namespace as
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
Now, first, what exactly does this link tell me and how does it help in xml rendering? So does it serve anything other than the uniqueness? And why go to such extent? If at all within a XML, I have conflict between two tags, I can just use any two namespaces, say namespace1 and namespace2 and work with it.
Is there something I am missing here?
In general, an XML namespace does not serve any purpose apart from uniquely identifying the elements that are associated with it.
In other words, the String "http://www.myNameSpace.com" as in:
is purely arbitrary. It does not have to point anywhere. Also, the so-called prefix (in this case
myNameSpace
, the part right after "xmlns:") is arbitrary and just a shorthand way of saying "http://www.myNameSpace.com".Having said that, a few reservations:
1) Namespaces can help structure your XML data in large files, for example a Microsoft Word document in OpenXML format:
This is an excerpt of the namespaces present in typical OOXML:
So, although there is no inherent reason to have separate namespaces, it helps dividing your XML vocabulary into meaningful categories.
2) There are a few constraints on arbitrarily defining namespaces, as you noticed:
This identifies elements as belonging to the XSLT namespace. But also, beyond that, it means that elements thus marked are identified by an XSLT processor as not merely being XML code, but an XSLT instruction to be carried out.
The link "http://www.w3.org/1999/XSL/Transform" points to the XSLT specification, where the rules for transforming XML documents are laid down. Now, to answer your question: Declaring the namespace does not help the transformation. Rather, an XSLT processor does not recognize XSLT code if you omit it.
You can define the namespaces "namespaceA" and "namespaceB":
but you cannot use them to transform XML, unless you meant to just change the prefix:
which is considered bad practice.
You've pretty much nailed it, i.e. the
xmlns
is unique. In addition, it must be a valid URI as per the W3C spec.From Wikipedia:
Re : XSLT
This means the namespace prefix
xsl
is now 'aliased' to thexmlns
"http://www.w3.org/1999/XSL/Transform" - i.e. all further identifiers in the document which reference thexsl
prefix belong in this namespace.Re : Comment
The choice of
xsl
as the prefix is by convention forxslt
stylesheets. There is nothing stopping you from using another alias, e.g.:But this isn't going to win you any friends.
You can also choose not to use the prefix, but then you'll need to repeat the
xmlns
everywhere e.g.The essence of XML Namespaces is that from the abstract data model point of view the name of an element/attribute/type/etc. consists of two parts, the namespace name (often called the "namespace URI") and the local part.
An element with namespace
http://www.w3.org/1999/XSL/Transform
and local partstylesheet
is different from an element with namespacehttp://example.com
and local partstylesheet
, which in turn is different from an element with the local namestylesheet
but no namespace. An XSLT processor would treat the first of those as an instruction but the second and third simply as literal elements to be output.It would be very verbose if you had to type out namespace names in full for every element:
so instead you use
xmlns
andxmlns:prefix
declarations to associate short (or empty) labels with the full namespace names, and then use those prefixes along with local names to provide the full name for each element. The prefix is not part of the name as far as a namespace-aware XML processor is concerned - it makes no difference what prefix you choose to use as long as it is bound to the correct namespace.However there are conventional prefixes that most people tend to use for common namespaces, for example
xsl
for XSLT,xs
orxsd
for XML schema,xsi
forhttp://www.w3.org/2001/XMLSchema-instance
, etc. and if you are writing XML that uses one of these vocabularies then it's a good idea to stick to the conventions if other people may need to read your documents in future.