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" ? return "Document" + (typeof this._file == "string" ?
": " + this._file : ""); ": " + this._file : "");
}, },
get innerHTML(){
return this.documentElement.outerHTML;
},
get defaultView(){ get defaultView(){
return { return {
@ -239,9 +242,9 @@ var window = this;
return "[ " + return "[ " +
Array.prototype.join.call( this, ", " ) + " ]"; Array.prototype.join.call( this, ", " ) + " ]";
}, },
valueOf: function(){ get outerHTML(){
return Array.prototype.map.call( 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(){ toString: function(){
return '"' + this.nodeValue + '"'; return '"' + this.nodeValue + '"';
}, },
valueOf: function(){ get outerHTML(){
return this.nodeValue; return this.nodeValue;
} }
}; };
@ -316,14 +319,14 @@ var window = this;
toString: function(){ toString: function(){
return "<" + this.tagName + (this.id ? "#" + this.id : "" ) + ">"; return "<" + this.tagName + (this.id ? "#" + this.id : "" ) + ">";
}, },
valueOf: function(){ get outerHTML(){
var ret = "<" + this.tagName, attr = this.attributes; var ret = "<" + this.tagName, attr = this.attributes;
for ( var i in attr ) for ( var i in attr )
ret += " " + i + "='" + attr[i] + "'"; ret += " " + i + "='" + attr[i] + "'";
if ( this.childNodes.length || this.nodeName == "SCRIPT" ) if ( this.childNodes.length || this.nodeName == "SCRIPT" )
ret += ">" + this.childNodes.valueOf() + ret += ">" + this.childNodes.outerHTML +
"</" + this.tagName + ">"; "</" + this.tagName + ">";
else else
ret += "/>"; ret += "/>";
@ -341,7 +344,7 @@ var window = this;
}, },
get innerHTML(){ get innerHTML(){
return this.childNodes.valueOf(); return this.childNodes.outerHTML;
}, },
set innerHTML(html){ set innerHTML(html){
html = html.replace(/<\/?([A-Z]+)/g, function(m){ html = html.replace(/<\/?([A-Z]+)/g, function(m){
@ -579,8 +582,29 @@ var window = this;
var self = this; var self = this;
function makeRequest(){ function makeRequest(){
var url = new java.net.URL(curLocation, self.url), var url = new java.net.URL(curLocation, self.url);
connection = url.openConnection();
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 // Add headers to Java connection
for (var header in self.headers) for (var header in self.headers)
@ -589,7 +613,7 @@ var window = this;
connection.connect(); connection.connect();
// Stick the response headers into responseHeaders // Stick the response headers into responseHeaders
for (var i=0; ; i++) { for (var i = 0; ; i++) {
var headerName = connection.getHeaderFieldKey(i); var headerName = connection.getHeaderFieldKey(i);
var headerValue = connection.getHeaderField(i); var headerValue = connection.getHeaderField(i);
if (!headerName && !headerValue) break; if (!headerName && !headerValue) break;
@ -597,14 +621,16 @@ var window = this;
self.responseHeaders[headerName] = headerValue; self.responseHeaders[headerName] = headerValue;
} }
self.readyState = 4; handleResponse();
self.status = parseInt(connection.responseCode); }
self.statusText = connection.responseMessage;
var stream = new java.io.InputStreamReader( function handleResponse(){
connection.getInputStream()), self.readyState = 4;
buffer = new java.io.BufferedReader(stream), self.status = parseInt(connection.responseCode) || undefined;
line; self.statusText = connection.responseMessage || "";
var stream = new java.io.InputStreamReader(connection.getInputStream()),
buffer = new java.io.BufferedReader(stream), line;
while ((line = buffer.readLine()) != null) while ((line = buffer.readLine()) != null)
self.responseText += line; self.responseText += line;
@ -619,6 +645,7 @@ var window = this;
self.responseText)).getBytes("UTF8"))); self.responseText)).getBytes("UTF8")));
} catch(e) {} } catch(e) {}
} }
}
self.onreadystatechange(); self.onreadystatechange();
} }