escape() 编码对 UTF-8 支持的不太好,我们应该用 encodeURI() 或者 encodeURIComponent() 来取代 escape() 。不过 encodeURI() 和 encodeURIComponent() 都需要 IE 5.5 以上才支持,FireFox 则完全没有问题。

        以下是 MSDN 对这三个编码函数的解释:

escape(charString)

escape 方法返回一个包含 charstring 内容的字符串值(Unicode 格式)。所有空格、标点、重音符号以及任何其他非 ASCII 字符都用 %xx 编码替换,其中 xx 等于表示该字符的十六进制数。例如,空格返回为“%20”。

字符值大于 255 的字符以 %uxxxx 格式存储。

注意 escape 方法不能用来对“统一资源标识符”(URI) 进行编码。

encodeURI(URIString)

encodeURI 方法返回一个已编码的 URI。如果将编码结果传递给 decodeURI,则将返回初始的字符串。encodeURI 不对下列字符进行编码:“:”、“/”、“;”和“?”。请使用 encodeURIComponent 对这些字符进行编码。

encodeURIComponent(encodedURIString)

encodeURIComponent 方法返回一个已编码的 URI。如果将编码结果传递给 decodeURIComponent,则将返回初始的字符串。因为 encodeURIComponent 方法将对所有字符编码,请注意,如果该字符串代表一个路径,例如 /folder1/folder2/default.html,则其中的斜杠也将被编码,这样,当该字符串作为请求发送到 Web 服务器时它将是无效的。如果字符串中包含多个 URI 组件,请使用 encodeURI 方法进行编码。

我们知道,使用 XMLHTTP.open(“GET”,url,false) 方法可以不刷新页面请求一个文件,再检查 XMLHTTP.status 属性可以判断请求的状态。但是上面的方法会载入整个请求的文件,如果仅仅需要判断请求的链接是否存在,我们使用 XMLHTTP.open(“HEAD”,url,false) 方法可以判断一个链接是否存在,并且不用把请求的文件全部下载回来。具体代码如下:

继续阅读

JavaScript里面有个parseInt函数,是用来把字符转成数字的,咱们一般这么用,返回值就是数字12了:

parseInt(“12ABC”) 

嗯,看上去很不错。再来看看下面两个会返回什么样的结果?

parseInt(“9”)

parseInt(“13”)

没错,他们分别返回了数字9和数字13。那么下面的两个呢?

parseInt(“09”)

parseInt(“013”)

看上去他们应该和前面两个一样返回数字9和13。但是结果并非如此:第一个返回了数字0,第二个返回了数字11。其实parseInt本来的语法是这样的:

parseInt(numString, [radix])

第一个参数是包含数字的字符串,第二个是转化时的进制。我们平时使用基本不带第二个参数,因为正常情况下按十进制转化,无须我们指定。但是0开头的字符串系统会认为是八进制数,09并不是合法的八进制数,所以返回了0;013从八进制转化成十进制正好是11。

我们要小心了,这种错误出现了一般很难察觉。所以,还是每次使用都带上第二个参数吧。

在Web编程中,经常会遇到js并不是按照书写的顺序执行的问题:A语句明明写在B语句前面,但是B语句确先执行了,往往只要在AB语句之间加入一个Alert就能恢复正常的顺序。但是不能无故弹对话框给用户看啊,真是莫名其妙的问题

下面这个暂停函数就是先弹出一个模式窗口,然后立刻关闭掉自己,不让用户看到这个窗口。有一个问题是如果安装了上网助手或者使用增强安全性的IE(比如XpSp2、2003),就需要进行相应的配置,否则窗口会被拦截掉的,导致Js错误而无法继续执行后面的代码。

继续阅读