Angularjs将json数据转换为“[object Object]”

时间:2016-10-28 05:52:46

标签: javascript angularjs arrays string object

我正在使用Angular资源进行ajax调用。我有一个更新事务,我从数据库中获取数据,而获取数据的数据是这样的: This is browser console when i am getting data from server

现在将数据添加到此对象的空字段后,我再次将其发送到服务器,然后在发送到服务器之前,数据将转换为不同的形式,如下所示: enter image description here

可能的原因是什么?我已经使用过JSON.parse();但它不起作用。

- 编辑 -

这是我将子对象转换为字符串

的代码
            var serverResp = res.data;
            $scope.importLC.main.customerName = serverResp.customerName;
            $scope.importLC.main.customerAddress1 = serverResp.customerAddress1;
            $scope.importLC.main.customerAddress2 = serverResp.customerAddress2;
            $scope.importLC.main.customerAddress3 = serverResp.customerAddress3;
            $scope.importLC.main.issueDate = $filter('date')(new Date(), 'dd-MM-yyyy');

            serverResp = $scope.importLC;

            angular.forEach(serverResp, function (value, key) {
                angular.forEach(serverResp[key], function (v, k) {
                    if (typeof serverResp[key][k] === 'object') {
                        angular.forEach(serverResp[key][k], function (v1, k1) {
                            serverResp[key][k][k1] = String(serverResp[key][k][k1]);
                        });
                    } else {
                        serverResp[key][k] = String(serverResp[key][k]);
                    }
                });
            });

            $scope.importLC = serverResp;

我必须将值转换为字符串,但整个对象转换为字符串。

- 编辑 -

我明白了数据转换的原因,实际上在将数据发送到服务器之前,我正在对数据进行验证,但验证文件只接受字符串值,所以我需要将数据转换为字符串,这里是代码

        //Convert object to string
        function convertObjectToStringSingleObject(data) {
            Object.keys(data).forEach(function (key) {
                data[key] = String(data[key]);
            });
            return data;
        }

在同一个地方我还有一个功能:

    //Convert object to string
    function convertObjectToStringMultiLevelObject(data) {
        Object.keys(data).forEach(function (key) {
            Object.keys(data[key]).forEach(function (key1) {
                data[key][key1] = String(data[key][key1]);
            });
        });
        return data;
    }

现在如果我使用convertObjectToStringMultiLevelObject函数,那么我的代码工作正常,但我的其他一些事务需要convertObjectToStringSingleObject。是否有任何方法可以将两个函数(convertObjectToStringSingleObjectconvertObjectToStringMultiLevelObject)结合起来,并且组合函数应该足够智能来捕获对象的类型,我的意思是它可以是单级或多级json对象。 / p>

2 个答案:

答案 0 :(得分:0)

在将对象转换为字符串时使用函数

var str = JSON.stringify(obj);

并在从Stringified对象转换为Javascript对象时使用

var obj  = JSON.parse(str);

修改

如果值为object

,请使用JSON.stringify
    function convertObjectToStringSingleObject(data) {
        Object.keys(data).forEach(function (key) {
            if (typeof data[key] === "object") {
               data[key] = JSON.stringify(data[key]);
            } else {
               data[key] = String(data[key]);
            }

        });
        return data;
    }

答案 1 :(得分:0)

做了一些R& D在这两个函数上我创建了一个组合函数,它允许我将对象(不同级别的对象)值转换为字符串,在我的情况下,对象的最大深层次为2,因此该函数将如下所示:

  function convertObjectToString(data) {
        Object.keys(data).forEach(function (key) {
            if (data[key] && typeof data[key] === 'object') {
                Object.keys(data[key]).forEach(function (key1) {
                    data[key][key1] = String(data[key][key1]);
                });
            } else if (data[key] && typeof data[key] === 'string' || typeof data[key] === 'number') {
                data[key] = String(data[key]);
            } else {
                data[key] = "";
            }

        });
        return data;
    }

我实现了我想要的东西,因为我知道了我的对象的深层次但我总是欢迎能够检查深层次并且可以相应地做出响应的功能。感谢。