js读取json数据(php传值给js)

简介:

 

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

如果直接用函数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.  
  3. foreach ($ajax as $key=>$val
  4. $ajax[$key]['name'] = urlencode($val['name']); 
  5. echo json_encode($json); 
  6.  
  7. ?> 

客户端js代码



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


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

原因是因为js 中decodeURI 仅仅支持utf8 转码
所以
php
代码应该为下面的代码
 
 
  
  1. <?php 
  2.  
  3. foreach ($ajax as $key=>$val
  4. $ajax[$key]['name'] = urlencode(iconv('gb2312','utf-8',$val['name'])); 
  5. echo json_encode($json); 
  6.  
  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. document.write(languages.cn.name); 
  12. </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.  
  12. for(var key in myJSONObject){ 
  13. alert(myJSONObject[key][0].regex) 
  14. </script> 

下面是json官方的js文件

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

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

function callback(rtval){

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

}

 



      本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/891443,如需转载请自行联系原作者



相关文章
|
6天前
|
JSON JavaScript 前端开发
JavaScript实现字符串转json对象的方法
JavaScript实现字符串转json对象的方法
|
2天前
|
JSON 前端开发 API
【淘系】商品详情属性解析(属性规格详情图sku等json数据示例返回参考),淘系API接口系列
在淘宝(或天猫)平台上,商品详情属性(如属性规格、详情图、SKU等)是商家在发布商品时设置的,用于描述商品的详细信息和不同规格选项。这些信息对于消费者了解商品特性、进行购买决策至关重要。然而,直接通过前端页面获取这些信息的结构化数据(如JSON格式)并非直接暴露给普通用户或开发者,因为这涉及到平台的商业机密和数据安全。 不过,淘宝平台提供了丰富的API接口(如淘宝开放平台API),允许有资质的开发者或合作伙伴通过编程方式获取商品信息。这些API接口通常需要注册开发者账号、申请应用密钥(App Key)和秘钥(App Secret),并遵守淘宝的API使用协议。
|
2天前
|
JSON Java Android开发
Android 开发者必备秘籍:轻松攻克 JSON 格式数据解析难题,让你的应用更出色!
【8月更文挑战第18天】在Android开发中,解析JSON数据至关重要。JSON以其简洁和易读成为首选的数据交换格式。开发者可通过多种途径解析JSON,如使用内置的`JSONObject`和`JSONArray`类直接操作数据,或借助Google提供的Gson库将JSON自动映射为Java对象。无论哪种方法,正确解析JSON都是实现高效应用的关键,能帮助开发者处理网络请求返回的数据,并将其展示给用户,从而提升应用的功能性和用户体验。
|
6天前
|
XML JSON Java
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
本文介绍了如何使用IntelliJ IDEA和Maven搭建一个整合了Struts2、Spring4、Hibernate4的J2EE项目,并配置了项目目录结构、web.xml、welcome.jsp以及多个JSP页面,用于刷新和学习传统的SSH框架。
15 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
17天前
|
JSON 前端开发 JavaScript
php中JSON或数组到formData的键值对转换
转换JSON或数组到formData格式的键值对并不复杂。PHP的 `json_decode()`与 `http_build_query()`是实现这一转换过程的关键函数。理解这个转换过程对于开发中处理各种AJAX请求时调整数据格式至关重要。这样,无论是处理来自客户端的JSON字符串,还是服务器端的数组数据,都能够灵活地转换为适合网络传输的格式,确保数据交换的顺畅和高效。
32 4
|
17天前
|
JavaScript 前端开发 网络安全
Node.js和php
【8月更文挑战第4天】Node.js和php
24 3
|
18天前
|
JSON 前端开发 Java
Spring MVC返回JSON数据
综上所述,Spring MVC提供了灵活、强大的方式来支持返回JSON数据,从直接使用 `@ResponseBody`及 `@RestController`注解,到通过配置消息转换器和异常处理器,开发人员可以根据具体需求选择合适的实现方式。
43 4
|
20天前
|
数据采集 JavaScript 数据挖掘
如何使用 PHP Simple HTML DOM Parser 轻松获取网页中的特定数据
本文介绍了使用PHP Simple HTML DOM Parser进行网页数据抓取的方法,尤其适用于从懂车帝二手车网站提取汽车品牌、价格和里程等关键信息。首先,安装并配置所需库,使用代理IP和设置cookie与useragent来模拟用户行为,避免被封。然后,通过编写PHP脚本,利用cURL获取网页内容,解析HTML并提取所需数据,最终将数据保存至CSV文件。文章强调了正确配置代理和用户代理的重要性,并提供了完整的PHP代码示例,以帮助读者理解和应用网页抓取技术。
如何使用 PHP Simple HTML DOM Parser 轻松获取网页中的特定数据
|
23小时前
|
JSON 前端开发 JavaScript
|
6天前
|
JSON JavaScript 数据格式
Jquery 将 JSON 列表的 某个属性值,添加到数组中,并判断一个值,在不在数据中
Jquery 将 JSON 列表的 某个属性值,添加到数组中,并判断一个值,在不在数据中
21 0

热门文章

最新文章