I think we all know how to use XML documents. For example RSS feeds are basically XML files, as well as sitemaps. Those files may be very important when managing a web site, but those examples are just a small part of the common use of XML documents. Just to make things clear, another example: when you export a Blogger blog, the file you get is an XML file.
When I've written the article on how to create an RSS feed, I discovered a very useful JavaScript snippet that helps us to validate an XML file.
Unfortunately I don't remember where I got it, but, even if I surely rearranged it, if you know the original source, please let me know so that I can give due credit to the author.
Ok, said that, let's see how to do it.
The code
First of all, let's create a form like the following:
<form name="form1">
<input type="file" name="file" size="50">
<input type="button" value="Validate" onclick="Validate()">
</form>
In the input element, we need to insert a valid path to an XML file (it can be local or remote, it doesn't matter).Then we have a button which will trigger the Validate() function:
<script type="text/javascript">
function Validate()
{
var file = document.form1.file.value;
// create an array in order to check the correct .xml extension in file
var arr_file = file.split(".");
var ext = arr_file[arr_file.length - 1]
// check if file is not empty - if not alert the user
if (file == "" || file == "undefined" || file.charAt(0) == " ")
{
alert("Please insert a file to check");
}
// check the file extension (.xml) - if not alert the user
else if (ext != "xml")
{
alert("The submitted file is not an XML file");
}
// if everything is ok, then
else
{
// create an XMLDOM
var x = new ActiveXObject("Microsoft.XMLDOM");
// load the submitted file
x.async = false;
x.load(file);
// set the XML parser to true
x.validateOnParse = true;
// check if there are errors
var errore = x.parseError.errorCode;
// if everything's ok, alert the user
if (errore == 0)
{
res.innerHTML = "No error found";
}
// if errors were found
else
{
// collect error information
var err_n = x.parseError.errorCode;
var err_d = x.parseError.reason;
var err_r = x.parseError.line;
// show the errors to the user
with (res)
{
innerHTML = "Error number " + err_n + "<br>";
innerHTML += " - " + err_d + "<br>";
innerHTML += "line " + err_r + "<br>";
}
}
// close the parser
x.Close();
}
}
</script>
I decided to leave the comments in the code itself, so it will be easier to understand what it is actually doing.Now, you may wonder what res is. Well, it's quite easy: we use a HTML element to show the results of the validation process. So somewhere on the page we need to insert the following:
<div id="res"></div>
That's the place where the results will appear.Let me know what you think.
Thanks for sharing this with us.
ReplyDeleteActiveXObject is only supported in IE. Can you provide me with alternate solutions for both Firefox and Chrome ?
ReplyDelete