js获取中文参数跳转时乱码

JavaScript012

js获取中文参数跳转时乱码,第1张

那不叫乱码,而是url编码,js本身就是读取url编码的

对于js获取url的中文可以尝试用escape() encodeURI() encodeURIComponent() decodeURI()

来使js停止或者转换url编码

一:Js的Url中传递中文参数乱码问题,重点:encodeURI编码,decodeURI解码:

1.传参页面

Javascript代码:<script type=”text/javascript”>// <![CDATA[

function send(){

var url = "test01.html"

var userName = $("#userName").html()

window.open(encodeURI(url + "?userName=" + userName))}

// ]]>

</script>

2. 接收参数页面:test02.html

<script>

var urlinfo = window.location.href//获取url

var userName = urlinfo.split(“?”)[1].split(“=”)[1]//拆分url得到”=”後面的参数

$(“#userName”).html(decodeURI(userName))

</script>

二:如何获取Url“?”后,“=”的参数值:

A.首先用window.location.href获取到全部url值。

B.用split截取“?”后的全部

C.split(“?”)后面的[1]内数字,默认从0开始计算

三:Js中escape,unescape,encodeURI,encodeURIComponent区别:

1.传递参数时候使用,encodeURIComponent否则url中很容易被”#”,”?”,”&”等敏感符号隔断。

2.url跳转时候使用,编码用encodeURI,解码用decodeURI。

3.escape() 只是为0-255以外 ASCII字符 做转换工作,转换成的 %u**** 这样的码,如果要用更多的字符如 UTF-8字符库 就一定要用 encodeURIComponent() 或 encodeURI() 转换才可以成 %nn%nn 这的码才可以,其它情况下escape,encodeURI,encodeURIComponent编码结果相同,所以为了全球的统一化进程,在用 encodeURIComponent() 或 encodeURI() 代替 escape() 使用

方法/步骤

1

首先查看你的程序页面的编码是什么字符编码的,如:gb2312还是utf-8类型的。

这个你写的程序不会不知道。

2

找到你下载的js文件,右击——选择打开方式——记事本。

注意,不要把默认设置成记事本,只是用记事本打开。

3

打开后单击菜单栏的文件选项——选择另存为。

4

在弹出的保存窗口的最下面有一个编码类型,将这个编码类型选择为你的程序的类型。然后保存。

5

调用刚刚另存的js文件,这是就不会出现乱码了。

http://jingyan.baidu.com/article/454316ab59cf70f7a7c03a02.html