Added better support for local file XHR, added document.innerHTML, change .valueOf() to be .outerHTML.

This commit is contained in:
John Resig 2007-07-10 02:38:20 +00:00
parent 0bb035a1ab
commit 7c85d973bf

View file

@ -187,6 +187,9 @@ var window = this;
return "Document" + (typeof this._file == "string" ?
": " + this._file : "");
},
get innerHTML(){
return this.documentElement.outerHTML;
},
get defaultView(){
return {
@ -239,9 +242,9 @@ var window = this;
return "[ " +
Array.prototype.join.call( this, ", " ) + " ]";
},
valueOf: function(){
get outerHTML(){
return Array.prototype.map.call(
this, function(node){return node.valueOf();}).join('');
this, function(node){return node.outerHTML;}).join('');
}
};
@ -282,7 +285,7 @@ var window = this;
toString: function(){
return '"' + this.nodeValue + '"';
},
valueOf: function(){
get outerHTML(){
return this.nodeValue;
}
};
@ -316,14 +319,14 @@ var window = this;
toString: function(){
return "<" + this.tagName + (this.id ? "#" + this.id : "" ) + ">";
},
valueOf: function(){
get outerHTML(){
var ret = "<" + this.tagName, attr = this.attributes;
for ( var i in attr )
ret += " " + i + "='" + attr[i] + "'";
if ( this.childNodes.length || this.nodeName == "SCRIPT" )
ret += ">" + this.childNodes.valueOf() +
ret += ">" + this.childNodes.outerHTML +
"</" + this.tagName + ">";
else
ret += "/>";
@ -341,7 +344,7 @@ var window = this;
},
get innerHTML(){
return this.childNodes.valueOf();
return this.childNodes.outerHTML;
},
set innerHTML(html){
html = html.replace(/<\/?([A-Z]+)/g, function(m){
@ -579,8 +582,29 @@ var window = this;
var self = this;
function makeRequest(){
var url = new java.net.URL(curLocation, self.url),
connection = url.openConnection();
var url = new java.net.URL(curLocation, self.url);
if ( url.getProtocol() == "file" ) {
if ( self.method == "PUT" ) {
var out = new java.io.FileWriter(
new java.io.File( new java.net.URI( url.toString() ) ) ),
text = new java.lang.String( data || "" );
out.write( text, 0, text.length() );
out.flush();
out.close();
} else if ( self.method == "DELETE" ) {
var file = new java.io.File( new java.net.URI( url.toString() ) );
file["delete"]();
} else {
var connection = url.openConnection();
connection.connect();
handleResponse();
}
} else {
var connection = url.openConnection();
connection.setRequestMethod( self.method );
// Add headers to Java connection
for (var header in self.headers)
@ -597,14 +621,16 @@ var window = this;
self.responseHeaders[headerName] = headerValue;
}
self.readyState = 4;
self.status = parseInt(connection.responseCode);
self.statusText = connection.responseMessage;
handleResponse();
}
var stream = new java.io.InputStreamReader(
connection.getInputStream()),
buffer = new java.io.BufferedReader(stream),
line;
function handleResponse(){
self.readyState = 4;
self.status = parseInt(connection.responseCode) || undefined;
self.statusText = connection.responseMessage || "";
var stream = new java.io.InputStreamReader(connection.getInputStream()),
buffer = new java.io.BufferedReader(stream), line;
while ((line = buffer.readLine()) != null)
self.responseText += line;
@ -619,6 +645,7 @@ var window = this;
self.responseText)).getBytes("UTF8")));
} catch(e) {}
}
}
self.onreadystatechange();
}