存档

文章标签 ‘添加新标签’

在debian上安装opera

2009年8月1日

[1]添加源
把下面的源添加到/etc/apt/sources.list
echo “deb http://deb.opera.com/opera/ testing non-free” >> /etc/apt/sources.list
# gpg –recv-key –keyserver wwwkeys.eu.pgp.net 033431536A423791
# gpg –export 033431536A423791 | apt-key add -

[2]aptitude update

[3]aptitude install opera

Linux , ,

获取 WordPress.com API Key

2009年2月23日

在使用WorkPress架站后,大多会使用内置的反垃圾留言插件Akismet,而使用该插件往在安装完成后需要输入WordPress.com API Key,根据所提供的地址,根本就过不去。这是因为workpress.com被干掉了,怎么办呢?

首先,去http://anchorfree.com下载一个Hotspot shield,安装后启动。它将给你一个VPN地址,这个可以不管。但至少得看到右下角它的图标为绿色,表示启动成功。

然后就可以直接打开wordpress.com站点。需要进行注册,注册完成后,就会往你里的邮箱里面发一封确认mail,剩下的就是点击该链接完成注册了。

这时你就拥有你的WorkPress.com API Key了。使用它的强大功能为你的BLOG护航吧

wordpress , , , , , ,

执行innerHTML中的Javascript

2009年2月10日

在使用AJAX时,往往只是将reponse的内容直接innerHTML到指定的容器里面,这种应用都非常简单。但是对于reponse的内容包含javascript内容时将如何处理呢?能否执行其返回的JS呢?

实际上,对于返回的内容,页面不会直接执行该JS代码,google一下,才发现关于这个问题的解决方法大概有三种:

1、首先在head标签内容设定一个指定ID的script标签,待响应时修改其src 属性。

2、创建一个iframe,然后将JS写入到该IFRAME中,对于要操作原页面的HTML标签,需要在里面的JS中添加parent。

3、应用较多的set_innerHTML,该函数是由andot所开发的。

以下为set_innerHTML函数内容。

var global_html_pool = [];
var global_script_pool = [];
var global_script_src_pool = [];
var global_lock_pool = [];
var innerhtml_lock = null;
var document_buffer = "";

function set_innerHTML(obj_id, html, time) {
if (innerhtml_lock == null) {
innerhtml_lock = obj_id;
}
else if (typeof(time) == "undefined") {
global_lock_pool[obj_id + "_html"] = html;
window.setTimeout("set_innerHTML('" + obj_id + "', global_lock_pool['" + obj_id + "_html']);", 10);
return;
}
else if (innerhtml_lock != obj_id) {
global_lock_pool[obj_id + "_html"] = html;
window.setTimeout("set_innerHTML('" + obj_id + "', global_lock_pool['" + obj_id + "_html'], " + time + ");", 10);
return;
}

function get_script_id() {
return "script_" + (new Date()).getTime().toString(36)
+ Math.floor(Math.random() * 100000000).toString(36);
}

document_buffer = "";

document.write = function (str) {
document_buffer += str;
}
document.writeln = function (str) {
document_buffer += str + "\n";
}

global_html_pool = [];

var scripts = [];
html = html.split(/<\/script>/i);
for (var i = 0; i < html.length; i++) {
global_html_pool[i] = html[i].replace(/<script[\s\S]*$/ig, "");
scripts[i] = {text: '', src: '' };
scripts[i].text = html[i].substr(global_html_pool[i].length);
scripts[i].src = scripts[i].text.substr(0, scripts[i].text.indexOf('>') + 1);
scripts[i].src = scripts[i].src.match(/src\s*=\s*(\"([^\"]*)\"|\'([^\']*)\'|([^\s]*)[\s>])/i);
if (scripts[i].src) {
if (scripts[i].src[2]) {
scripts[i].src = scripts[i].src[2];
}
else if (scripts[i].src[3]) {
scripts[i].src = scripts[i].src[3];
}
else if (scripts[i].src[4]) {
scripts[i].src = scripts[i].src[4];
}
else {
scripts[i].src = "";
}
scripts[i].text = "";
}
else {
scripts[i].src = "";
scripts[i].text = scripts[i].text.substr(scripts[i].text.indexOf('>') + 1);
scripts[i].text = scripts[i].text.replace(/^\s*<\!--\s*/g, "");
}
}

var s;
if (typeof(time) == "undefined") {
s = 0;
}
else {
s = time;
}

var script, add_script, remove_script;

for (var i = 0; i < scripts.length; i++) {
var add_html = "document_buffer += global_html_pool[" + i + "];\n";
add_html += "document.getElementById('" + obj_id + "').innerHTML = document_buffer;\n";
script = document.createElement("script");
if (scripts[i].src) {
script.src = scripts[i].src;
if (typeof(global_script_src_pool[script.src]) == "undefined") {
global_script_src_pool[script.src] = true;
s += 2000;
}
else {
s += 10;
}
}
else {
script.text = scripts[i].text;
s += 10;
}
script.defer = true;
script.type =  "text/javascript";
script.id = get_script_id();
global_script_pool[script.id] = script;
add_script = add_html;
add_script += "document.getElementsByTagName('head').item(0)";
add_script += ".appendChild(global_script_pool['" + script.id + "']);\n";
window.setTimeout(add_script, s);
remove_script = "document.getElementsByTagName('head').item(0)";
remove_script += ".removeChild(document.getElementById('" + script.id + "'));\n";
remove_script += "delete global_script_pool['" + script.id + "'];\n";
window.setTimeout(remove_script, s + 10000);
}

var end_script = "if (document_buffer.match(/<\\/script>/i)) {\n";
end_script += "set_innerHTML('" + obj_id + "', document_buffer, " + s + ");\n";
end_script += "}\n";
end_script += "else {\n";
end_script += "document.getElementById('" + obj_id + "').innerHTML = document_buffer;\n";
end_script += "innerhtml_lock = null;\n";
end_script += "}";
window.setTimeout(end_script, s);
}

在实际的应用中稍有修改。例如,对于第一次使用ajax所返回的HTML中的JS来修改所返回的HTML中的某个DIV,这样往往会看不到实际修改的结果。经研究发现,曾执行了两次写入操作。于此,只需要将修改操作的timeout的时间改长一点即可(即add_script的执行时间)。

HTML, Javascript , , , , , , ,