将PHP数组赋值给JS通过php系统函数json_encode()来实现

<?php

$array =array('fds','fdsa','fdsafasd');

//json_encode($array);

?>

<html>

<head>

<scripttype="text/javascript">

varreadpoint=<?phpechojson_encode($array);?>;//***注意不要用引号,如果用了json存储的数组就成字符串了。另外如果有键名要以对象的形式弹出如readpoint.id

alert(readpoint[0]);//fds

</script>

</head>

</html>[/code]

通过JSON(测试成功) 因为JS能识别JSON格式的数据(php跟js的共同点所以这样传值才有效,那xml呢也许可以就算可以也会比较麻烦不提倡。用json就是为了方便否则直接用字符串传也是一样用JS把字符串在还原成数组。)

如果不用JSON的话,本人也尝试过但没有测试成功。弹出某个元素的时候会出现未定义的错误。(测试失败)

当然我们也可以不用赋值直接在js里使用PHP数组(测试成功)。 ***注意前提是赋值数组不是某个变量***

-----------------------------------------------------

(参考) 如果出现一下问题的话 。本人通过上面方法就可以实现了

json 是一个很好的数据结构现在已经广泛用在网络数据传输上

php自身待了两个和json相关的函数

json_encode和json_decode

这两个函数的具体用法网上有很多相关的文章

本文主要介绍用json_encode时中文无法转换的解决方案

本文假设文件所用的编码为gb2312;

先写出所需的数组

<?php

$json=array(

0=>

array(

'id'=>'13',

'name'=>'乒乓球',

),

1=>

array(

'id'=>'17',

'name'=>'篮球',

)

)

?>

如果直接用函数json_encode

<?php

echojson_encode($json);

?>

结果为:

<?php

[{"id":"13","name":null},{"id":"13","name":null}]

?>

可以看到汉字没有被转义都为null

这是因为json仅仅转义encoding编码

故上面语句应该先转换编码

<?php

foreach($ajaxas$key=>$val)

{

$ajax[$key]['name']=urlencode($val['name']);

}

echojson_encode($json);

?>

客户端js代码

<scripttype="text/javascript">

functiongetsort(obj)

{

$.ajax(

{

type:"GET",

url:"<?=$this->baseUrl?>/index/getajax",

data:"c="obj.value,

success:function(json)

{

varjson=eval(json);

varhtml='<select>';

$.each(json,function(k)

{

html='<optionvalue="'json[k]['id']'">'decodeURI(json[k]['name'])'</option>';

});

html="</select>";

$('#sort').html(html);

}

}

)

}

</script>

用上面的代码js会报错说编码不符合标准

原因是因为js中decodeURI仅仅支持utf8转码

所以

php

代码应该为下面的代码

<?php

foreach($ajaxas$key=>$val)

{

$ajax[$key]['name']=urlencode(iconv('gb2312','utf-8',$val['name']));

}

echojson_encode($json);

?>

-------------------------------------------------------------------

js读取json数据

2010-03-22 来自:博客园 字体大小:【大 中 小】
  • 摘要:本文介绍在js中读取json数据

示例如下:

<script type="text/javascript" language="javascript">

varlanguages={

cn:{

lang:'ch',

name:"中文"

},

en:{

lang:"英文",

name:"en"

}

};

document.write(languages.cn.name);

</script>

=====================================================================请问有没有详细的js读取json的例子方法

//根据city获得name

functiongetNameByCity(city)

{

varcityName=

{

"0556":"安庆市",

"0372":"安阳市",

};

returncityName[city];

}

(参考) =====================================================================

js中读取JSON的方法探讨

js读取JSON的方法我接触到的有两种:

方法一:函数构造定义法返回

varstrJSON="{name:'jsonname'}";//得到的JSON

varobj=newFunction("return"+strJSON)();//转换后的JSON对象

alert(obj.name);//json name

方法二:js中著名的eval函数

varstrJSON="{name:'jsonname'}";//得到的JSON

varobj=eval("("+strJSON+")");//转换后的JSON对象

alert(obj.name);//json name

第二种方法需要注意的是,对象表达式{'name':'json name'}必须用“()”扩住,否则

varstrJSON="{name:'jsonname'}";

varobj=eval(strJSON);

alert(obj.constructor);//String构造函数

alert(obj.name);//undefine

必须把对象表达式扩起来eval执行才能生成一个匿名对象!

(参考)--------------------------------------------------------------------------

下面json官方的js,结合ajax来读取解释json结构的数据。

<script>

//直接声明json数据结构

varmyJSONObject={"bindings":[

{"ircEvent":"PRIVMSG","method":"newURI","regex":"^http://.*"},

{"ircEvent":"PRIVMSG","method":"deleteURI","regex":"^delete.*"},

{"ircEvent":"PRIVMSG","method":"randomURI","regex":"^random.*"}

]

};

alert(myJSONObject["bindings"][0].method); //这里读取节点bindings中第一个数组位置method的值

也可以使用循环来读取

for(var key in myJSONObject){

alert(myJSONObject[key][0].regex)

}

</script>

下面是json官方的js文件

<script src="json2.js"></script>

// rtval的值:{"digg":[{"diggnum":"12","offnum":"0","pageviews":"680","username":"dodo"}]}

function callback(rtval)

{

var myJSONObject2=eval("("+rtval+")");alert(myJSONObject2["digg"][0].diggnum)

}

</script>

相关推荐