设为首页 收藏本站
查看: 531|回复: 0

[经验分享] 将PHP数组赋值给JS通过php系统函数json_encode()来实现

[复制链接]

尚未签到

发表于 2017-4-3 13:00:38 | 显示全部楼层 |阅读模式
  <?php
  $array =array('fds','fdsa','fdsafasd');
// json_encode($array);

?>

<html>
<head>
<script type="text/javascript">
   var readpoint = <?php echo json_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

    
echo json_encode($json);
?>


结果为:

<?php
[{"id":"13","name":null},{"id":"13","name":null}]
?>



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

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

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

<?php

        
foreach ($ajax as $key=>$val)
         {
            
$ajax[$key]['name']     = urlencode($val['name']);
         }
         echo
json_encode($json);

?>


客户端js代码


<script   type="text/javascript">
function getsort(obj)
{
             $.ajax(
             {
                 type : "GET",    
                 url : "<?=$this->baseUrl?>/index/getajax",
                 data : "c=" obj.value,
                 success : function(json)
                 {    
                     var json=eval(json);
                
                     var html = '<select>';
                     $.each(json, function(k)
                     {
                         html   = '<option value="'    json[k]['id']    '">'    decodeURI(json[k]['name'])    '</option>';
                     });
                     html   ="</select>";
                     $('#sort').html(html);
                 }
             }
             )
}
</script>



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

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

<?php

        
foreach ($ajax as $key=>$val)
         {
            
$ajax[$key]['name']     = urlencode(iconv('gb2312','utf-8',$val['name']));
         }
         echo
json_encode($json);

?>

  -------------------------------------------------------------------
js读取json数据
2010-03-22 来自:博客园 字体大小:【

  • 摘要:本文介绍在js中读取json数据

  示例如下:
<script type="text/javascript" language="javascript">
var languages = {
     cn:{
     lang:
'ch',
     name:
"中文"
},
en:{
     lang:
"英文",
     name:
"en"
}
};
document.write(languages.cn.name);
</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( "(" + strJSON + ")" );//转换后的JSON对象
alert(obj.name);//json name
  第二种方法需要注意的是,对象表达式{'name':'json name'}必须用“()”扩住,否则
var strJSON = "{name:'json name'}";
var obj = eval(strJSON);
alert(obj.constructor);//String 构造函数
alert(obj.name);//undefine
必须把对象表达式扩起来eval执行才能生成一个匿名对象!
  (参考)--------------------------------------------------------------------------
  下面json官方的js,结合ajax来读取解释json结构的数据。
  <script>
  //直接声明json数据结构
var myJSONObject = {"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>

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-359615-1-1.html 上篇帖子: php导出Excel php导入Excel PhpExcel使用说明 PhpExcel使用手册 下篇帖子: 浪潮php实习第二天(php开源框架zend Framework初探)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表