繁体   English   中英

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

[英]Angularjs converting json data to “[object Object]”

我正在使用Angular资源进行ajax调用。 我有一个更新事务,我从数据库中获取数据,而获取数据的数据是这样的: 当我从服务器获取数据时,这是浏览器控制台

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

可能的原因是什么? 我已经使用过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对象。

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

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;
    }

在对这两个函数进行了一些研发之后,我创建了一个组合函数,它允许我将对象(不同级别的对象)值转换为字符串,在我的情况下,对象的最大深层是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;
    }

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM