Gazelle/static/functions/class_ajax.js

117 lines
3.2 KiB
JavaScript
Raw Normal View History

2011-03-28 14:21:28 +00:00
/*
TODO: Further optimize serialize function
UPDATE: We were forced to create an individual XHR for each request
to avoid race conditions on slower browsers where the request would
be overwritten before the callback triggered, and leave it hanging.
This only happened in FF3.0 that we tested.
Example usage 1:
ajax.handle = function () {
$('#preview' + postid).raw().innerHTML = ajax.response;
$('#editbox' + postid).hide();
}
ajax.post("ajax.php?action=preview","#form-id" + postid);
Example usage 2:
ajax.handle = function() {
$('#quickpost').raw().value = "[quote="+username+"]" + ajax.response + "[/quote]";
}
ajax.get("?action=get_post&post=" + postid);
*/
"use strict";
var json = {
encode: function (object) {
try {
return JSON.stringify(object);
} catch (err) {
return '';
}
},
decode: function (string) {
if (window.JSON && JSON.parse) {
return JSON.parse(string);
} else {
return eval("(" + string + ")");
//return (new Function("return " + data))();
}
}
};
var ajax = {
get: function (url, callback) {
var req = (typeof(window.ActiveXObject) === 'undefined') ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");
if (callback !== undefined) {
req.onreadystatechange = function () {
if (req.readyState !== 4 || req.status !== 200) {
return;
}
callback(req.responseText);
};
}
req.open("GET", url, true);
req.send(null);
},
post: function (url, data, callback) {
var req = isset(window.ActiveXObject) ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest();
var params = ajax.serialize(data);
if (callback !== undefined) {
req.onreadystatechange = function () {
if (req.readyState !== 4 || req.status !== 200) {
return;
}
callback(req.responseText);
};
}
req.open('POST', url, true);
req.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
req.send(params);
},
serialize: function (data) {
var query = '',
elements;
if (is_array(data)) {
for (var key in data) {
query += key + '=' + encodeURIComponent(data[key]) + '&';
}
} else {
elements = document.getElementById(data).elements;
for (var i = 0, il = elements.length; i < il; i++) {
var element = elements[i];
if (!isset(element) || element.disabled || element.name === '') {
continue;
}
switch (element.type) {
case 'text':
case 'hidden':
case 'password':
case 'textarea':
case 'select-one':
query += element.name + '=' + encodeURIComponent(element.value) + '&';
break;
case 'select-multiple':
for (var j = 0, jl = element.options.length; j < jl; j++) {
var current = element.options[j];
if (current.selected) {
query += element.name + '=' + encodeURIComponent(current.value) + '&';
}
}
break;
case 'radio':
if (element.checked) {
query += element.name + '=' + encodeURIComponent(element.value) + '&';
}
break;
case 'checkbox':
if (element.checked) {
query += element.name + '=' + encodeURIComponent(element.value) + '&';
}
break;
}
}
}
return query.substr(0, query.length - 1);
}
};