1. <?php
  2. $array =array('fds','fdsa','fdsafasd');  // json_encode($array);
  3. ?>
  4. <html>
  5. <head>
  6. <script type="text/javascript">
  7. var readpoint = <?php echo json_encode($array);?>; //***注意不要用引号,如果用了json存储的数组就成字符串了。另外如果有键名要以对象的形式弹出如readpoint.id
  8. alert(readpoint[0]);//fds
  9. </script>
  10. </head>
  11. </html>

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

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

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

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

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

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

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

这两个函数的具体用法 网上有很多相关的文章
本文主要介绍 用json_encode 时 中文无法转换的解决方案

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

先写出所需的数组

  1. <?php
  2. $json = array (
  3. 0 =>
  4. array (
  5. 'id' => '13',
  6. 'name' => '乒乓球',
  7. ),
  8. 1 =>
  9. array (
  10. 'id' => '17',
  11. 'name' => '篮球',
  12. )
  13. )
  14. ?>

如果直接用函数json_encode

  1. <?php
  2. echo json_encode($json);
  3. ?>

结果为:

  1. <?php
  2. [{"id":"13","name":null},{"id":"13","name":null}]
  3. ?>

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

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

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

  1. <?php
  2. foreach ($ajax as $key=>$val)
  3. {
  4. $ajax[$key]['name'] = urlencode($val['name']);
  5. }
  6. echo json_encode($json);
  7. ?>

客户端js代码

  1. <script type="text/javascript">
  2. function getsort(obj)
  3. {
  4. $.ajax(
  5. {
  6. type : "GET",
  7. url : "<?=$this->baseUrl?>/index/getajax",
  8. data : "c=" obj.value,
  9. success : function(json)
  10. {
  11. var json=eval_r(json);
  12. var html = '<select>';
  13. $.each(json, function(k)
  14. {
  15. html = '<option value="' json[k]['id'] '">' decodeURI(json[k]['name']) '</option>';
  16. });
  17. html ="</select>";
  18. $('#sort').html(html);
  19. }
  20. }
  21. )
  22. }
  23. </script>

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

原因是因为js 中decodeURI 仅仅支持utf8 转码
所以
php
代码应该为下面的代码

 
  1. <?php
  2. foreach ($ajax as $key=>$val)
  3. {
  4. $ajax[$key]['name'] = urlencode(iconv('gb2312','utf-8',$val['name']));
  5. }
  6. echo json_encode($json);
  7. ?>

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

js读取json数据

示例如下:

 
  1. <script type="text/javascript" language="javascript">
  2. var languages = {
  3. cn:{
  4. lang:'ch',
  5. name:"中文"
  6. },
  7. en:{
  8. lang:"英文",
  9. name:"en"
  10. }
  11. };
  12. document.write(languages.cn.name);
  13. </script>

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

//根据city获得name
function getNameByCity(city)
{
var cityName =
{
"0556":"安庆市",
"0372":"安阳市",
};
return cityName[city];
}

(参考) =====================================================================
js 中读取JSON的方法探讨

js读取JSON的方法我接触到的有两种:
方法一:函数构造定义法返回
var strJSON = "{name:'json name'}";//得到的JSON
var obj = new Function("return" + strJSON)();//转换后的JSON对象
alert(obj.name);//json name

方法二:js中著名的eval函数
var strJSON = "{name:'json name'}";//得到的JSON
var obj = eval_r( "(" + strJSON + ")" );//转换后的JSON对象
alert(obj.name);//json name

第二种方法需要注意的是,对象表达式{'name':'json name'}必须用“()”扩住,否则
var strJSON = "{name:'json name'}";
var obj = eval_r(strJSON);
alert(obj.constructor);//String 构造函数
alert(obj.name);//undefine
必须把对象表达式扩起来eval执行才能生成一个匿名对象!

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

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

  1. <script>
  2. //直接声明json数据结构
  3. var myJSONObject = {"bindings": [
  4. {"ircEvent": "PRIVMSG", "method": "newURI", "regex": "^http://.*"},
  5. {"ircEvent": "PRIVMSG", "method": "deleteURI", "regex": "^delete.*"},
  6. {"ircEvent": "PRIVMSG", "method": "randomURI", "regex": "^random.*"}
  7. ]
  8. };
  9. alert(myJSONObject["bindings"][0].method);
  10. //这里读取节点bindings中第一个数组位置method的值,也可以使用循环来读取
  11. for(var key in myJSONObject){
  12. alert(myJSONObject[key][0].regex)
  13. }
  14. </script>

下面是json官方的js文件

<script src=\'#\'" /script>

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

function callback(rtval){

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

}

js读取json数据(php传值给js)的更多相关文章

  1. js读取json数据

    { "code": 0, "msg": null, "data": { "pageNum": 1, "page ...

  2. js 读取json数据 挖坑

    一般遇到后台给的json数据格式不对 比如key和value都是单引号. 但真正的json 的key和value都是双引号,必须双引号才能取值. 再来一个例子看看 var test = [{ &quo ...

  3. js循环读取json数据,将读取到的数据用js写成表格

    ①js循环读取json数据的方式: var data=[{"uid":"2688","uname":"*江苏省南菁高级中学 022 ...

  4. js进阶ajax读取json数据(ajax读取json和读取普通文本,和获取服务器返回数据(链接)都是一样的,在url处放上json文件的地址即可)

    js进阶ajax读取json数据(ajax读取json和读取普通文本,和获取服务器返回数据(链接)都是一样的,在url处放上json文件的地址即可) 一.总结 ajax读取json和读取普通文本,和获 ...

  5. js声明json数据,打印json数据,遍历json数据

    1.js声明json数据: 2.打印json数据: 3.遍历json数据 //声明JSON var json = {}; json.a = 1; //第一种赋值方式(仿对象型) json['b'] = ...

  6. JS解析json数据并将json字符串转化为数组的实现方法

    json数据在ajax实现异步交互时起到了很重要的作用,他可以返回请求的数据,然后利用客户端的js进行解析,这一点体现出js的强大,本文介绍JS解析json数据并将json字符串转化为数组的实现方法, ...

  7. JS解析json数据

    JS解析json数据(如何将json字符串转化为数组) 1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN&q ...

  8. 初探原生js根据json数据动态创建table

    初探原生js根据json数据动态创建table 小生以实习生的职位进入了一家非纯软件的公司做asp.net开发,大半个月下来发现公司里居然没有前端工程师,这令我很诧异,跟着公司做项目,发现前端后台没有 ...

  9. js处理json数据,java处理json数据

    一.js处理json数据 处理办法之一是把本机json数据或远程返回json数据用eval函数,使之变成DOM对象. 例如: var people = { "programmers" ...

随机推荐

  1. 函数查询(Function Query)

    函数查询 可以利用 numeric字段的值 或者 与字段相关的的某个特定的值的函数,来对文档进行评分. 1.    使用函数查询的方法 这里主要有三种方法可以使用函数查询,这三种s方法都是通过solr ...

  2. Comparison method violates its general contract

    生产环境出现的错误排查,错误log如下 java.lang.IllegalArgumentException: Comparison method violates its general contr ...

  3. nodejs的mysql模块学习(五)数据库连接配置之SSL

    SSL选项 在SSL连接选项中需要一个字符串 或者对象 当是字符串的时候 将使用预定义的SSL配置文件 "Amazon RDS" 只有这一个预定义配置文件 用来连接到亚马逊RDS服 ...

  4. 10 个顶级 JavaScript 动画框架推荐

    使用JavaScript可以做出一些引人注目的动画效果,但通常不太容易实现.本文为你整理了10个非常优秀的JavaScript动画框架,使用它们你可以轻松实现动画效果.1. RaphaëlRaphaë ...

  5. cannot find module 'cordova-common'

    解决办法,重新安装cordova npm install -g cordova

  6. Kinect For Windows V2开发日志六:人体的轮廓的表示

    Kinect中带了一种数据源,叫做BodyIndex,简单来说就是它利用深度摄像头识别出最多6个人体,并且用数据将属于人体的部分标记,将人体和背景区别开来.利用这一特性,就可以在环境中显示出人体的轮廓 ...

  7. BZOJ 1146: [CTSC2008]网络管理Network 树链剖分+线段树+平衡树

    1146: [CTSC2008]网络管理Network Time Limit: 50 Sec  Memory Limit: 162 MBSubmit: 870  Solved: 299[Submit] ...

  8. C/C++程序通过动态链接库调用MATLAB程序

    C/C++程序通过动态链接库调用MATLAB程序 1 MATLAB编译器设置 需要设定对应的C++编译器才能编译.m文件生成可供C++调用的库文件. 在MATLAB命令行输入:mex –setup:然 ...

  9. OpenShare常见问题及解答

    OpenShare常见问题及回答: Q:OpenShare可以整合SAP么? A:当然可以,OpenShare是真正完全开放的产品,但要进行二次开发,事实上我们帮我们大部分的客户都整合了SAP,包括数 ...

  10. Fuck Sharepoint 2013

    最近遇到一个貌似是bug的问题,每次点击页面的时候页面的地址多出一行/_layouts/15/start.aspx#/ 然后跑到google上搜索出解决方案, 地址:http://social.tec ...