gpt4 book ai didi

javascript - Internet Explorer 中的 ROT-13 链接解码失败

转载 作者:行者123 更新时间:2023-12-02 20:16:32 27 4
gpt4 key购买 nike

我将网站上的所有电子邮件地址编码为 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com