我将网站上的所有电子邮件地址编码为 ROT-13,然后使用 Javascript 对地址进行解码(以避免垃圾邮件)。然而,在 IE 7 或 8 中,解码完全不起作用。在 Chrome、Safari、Firefox 中工作得非常好。关于出了什么问题有什么想法吗?
更新 链接“href”已正确解码,并且单击时链接实际上可以正常工作。因此,只有链接文本(HTML 内容)无法解码。
这是我正在使用的代码:
/***********************************************
DECODE ROT13 EMAIL LINKS
***********************************************/
$('a.email-encoded').each(function() {
$(this).attr('href', rot13x($(this).attr('href')));
$(this).html(rot13x($(this).html()));
});
function rot13x(s) {
var rxi = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
var rxo = 'NOPQRSTUVWXYZABCDEFGHIJKLMnopqrstuvwxyzabcdefghijklm5678901234';
var map = [];
var buf = '';
for (z = 0; z < rxi.length; z++) {map[rxi.substr(z, 1)] = rxo.substr(z, 1);}
for (z = 0; z < s.length; z++) {
var c = s.charAt(z);
buf += (c in map ? map[c] : c);
}
return buf;
}
最佳答案
每当我看到for
时我都会担心循环从零开始并使用 <=
其停止条件:
for (z = 0; z <= s.length; z++) {
这个习惯用法使得取消引用 s[0]
变得非常容易。和s[length]
,当最后定义的元素通常是 s[length-1]
时.
IE 的 JavaScript 引擎如何处理字符串越界读写?
关于javascript - Internet Explorer 中的 ROT-13 链接解码失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6220729/