首页 > 代码库 > 对象和数组-把数据转换成对象

对象和数组-把数据转换成对象

————————————————————————————————————

<script type="text/javascript">    
            //根据用户的输入,创建对象的数据
            function buildObj(){
                //获取新元素key和val的dom
                var key = document.getElementById(‘key‘).value;
                var val = document.getElementById(‘val‘).value;
                //取得当前对象文本的内容
                var str = document.getElementById(‘obj_txt‘).innerHTML.trim();
                //把字符转换成JavaScript的对象
                var obj = str==‘‘?{}:eval(‘(‘+str+‘)‘);
                //使用正则表达式,如果是数字型的数据,则直接连接,否则需要加上单引号
                if(/\d+\.?\d*/.test(val))
                    obj[key] = val;    
                else
                    obj[key] = ‘\‘‘+val+‘\‘‘;    //对val加上单引号
                //把最新的对象的文本形式打印出来
                document.getElementById(‘obj_txt‘).innerHTML = convertObj(obj);
            }            
            //把对象转换成文本形式 ,这也是json转换的形式
            function convertObj(obj){
                var str = ‘{‘;                //定义字符变量,用于串联
                for(var prop in obj){        //便利对象的属性
                    //如果为对象类型,则遍历连接
                    if(typeof(obj[prop]) == ‘object‘){
                        str += prop+‘:‘+convertObj(obj[prop])+‘,‘;
                    //如果是字符形式,则需要加单引号
                    }else if(typeof(obj[prop]) == ‘string‘){
                        str += prop+‘:\‘‘+obj[prop]+‘\‘,‘;
                    //其他的则直接显示
                    }else{
                        str += prop+‘:‘+obj[prop]+‘,‘;
                    }
                }
                //把最后一个逗号去掉,否则不是标准的形式
                if(str.charAt(str.length-1) == ‘,‘){
                    str = str.substr(0,str.length-1);
                }
                str += ‘}‘;                    //拼接最后一个大括号
                return str;                    //返回最后的拼接结果字符
            }
        </script>

————————————————————————————————————

convetObj()函数的功能是把数据从字符形式转换为对象形式,其中还用到了递归方法。

在该函数中,需要首先考虑数据的类型,基本的数据类型只是数字型和字符型,数字型不必加单引号,而字符型需要加单引号。

对象和数组-把数据转换成对象