欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

ajax前端的关联数组转json到后台方法

程序员文章站 2024-01-26 13:15:28
...
这次给大家带来ajax前端的关联数组转json到后台方法,ajax前端的关联数组转json到后台的注意事项有哪些,下面就是实战案例,一起来看一下。

很多人碰到过ajax传值时无法直接传数组,而百度的大多数都是不能用的

所以我想到了一个方法:

第一步:将数组转换为json字符串

这是一个技术性的问题,百度说的JSON.stringify(arr)是不能转换关联数组的,甚至索引数组也是有很多缺点

所以我特意封装了个js递归函数

function arrToJSON(arr) {
    var json = {};
    for (var i in arr) {
        var vo=arr[i];
        if (typeof arr[i] == "object") {
            json[i]={};
            json[i] = arrToJSON(vo);
        } else {
            json[i] =vo;
        }
    }
    return JSON.stringify(json);
}

只要传入js多维数组,能把数组全部解析为字符串

这样就可以在ajax里面传值啦~~~

第二步 :

但是这样转换成的json字符串是不完整的,不能直接解析出全部的数组

如图

ajax前端的关联数组转json到后台方法

可以发现,这个函数会将下级的子json字符串给用斜杠转义,越往下走斜杠越多,

当后台json_decode 处理第一层级时,第二层其实仍是json_decode字符串

所以后台需要一个新的decode函数用于解析这个json字符串

/**
 * 解析前台传来的不完整json字符串
 */
private function json_decode_x($str)
{
    $data_arr = array();
    $arr = json_decode($str, 1);
    foreach ($arr as $x => $a) {
        if (preg_match('/":/', $arr[$x])) { //匹配
            $data_arr[$x] = $this->json_decode_x($a);
        } else {
            $data_arr[$x] = $a;
        }
    }
    return $data_arr;
}

这样的话,后台接收到json字符串,用这个函数解析,就可以得到完整正确的多维数组了

由于我的业务需求,是没有/" 这样的字符串的,所以可以用这个来判断子字符串是否还有json字符串可以解析,如果用到实际上项目,请修改该正则判断

当然有能力的人可以直接第一步改成完整的json字符串,这样后台可以直接用一个json_decode解析

相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!

推荐阅读:

怎样阻止JS的冒泡和浏览器的默认行为

JS怎样刷新父页面

js与canvas合成图片做出微信公众号海报功能

以上就是ajax前端的关联数组转json到后台方法的详细内容,更多请关注其它相关文章!