扩展juery 将 js object对象 转成 json结构字符串 用于ajax 传递json (验证可用)后台 对应fastJSON

本文展示了如何使用jQuery将复杂的数据结构转换为JSON字符串,并通过创建特定的数据包来实现数据的有效组织和传输。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(function($) { 
    // the code of this function is from  
    // http://lucassmith.name/pub/typeof.html 
    $.type = function(o) { 
        var _toS = Object.prototype.toString; 
        var _types = { 
            'undefined': 'undefined', 
            'number': 'number', 
            'boolean': 'boolean', 
            'string': 'string', 
            '[object Function]': 'function', 
            '[object RegExp]': 'regexp', 
            '[object Array]': 'array', 
            '[object Date]': 'date', 
            '[object Error]': 'error' 
        }; 
        return _types[typeof o] || _types[_toS.call(o)] || (o ? 'object' : 'null'); 
    }; 
    // the code of these two functions is from mootools 
    // http://mootools.net 
    var $specialChars = { '\b': '\\b', '\t': '\\t', '\n': '\\n', '\f': '\\f', '\r': '\\r', '"': '\\"', '\\': '\\\\' }; 
    var $replaceChars = function(chr) { 
        return $specialChars[chr] || '\\u00' + Math.floor(chr.charCodeAt() / 16).toString(16) + (chr.charCodeAt() % 16).toString(16); 
    }; 
    $.toJSON = function(o) { 
        var s = []; 
        switch ($.type(o)) { 
            case 'undefined': 
                return 'undefined'; 
                break; 
            case 'null': 
                return 'null'; 
                break; 
            case 'number': 
            case 'boolean': 
            case 'date': 
            case 'function': 
                return o.toString(); 
                break; 
            case 'string': 
                return '"' + o.replace(/[\x00-\x1f\\"]/g, $replaceChars) + '"'; 
                break; 
            case 'array': 
                for (var i = 0, l = o.length; i < l; i++) { 
                    s.push($.toJSON(o[i])); 
                } 
                return '[' + s.join(',') + ']'; 
                break; 
            case 'error': 
            case 'object': 
                for (var p in o) { 
                    s.push(p + ':' + $.toJSON(o[p])); 
                } 
                return '{' + s.join(',') + '}'; 
                break; 
            default: 
                return ''; 
                break; 
        } 
    }; 
    $.evalJSON = function(s) { 
        if ($.type(s) != 'string' || !s.length) return null; 
        return eval('(' + s + ')'); 
    }; 
})(jQuery); 

/**
 * 
 * _ActionType = "insert or update or delete or select" and diy your sign eg:select4InitByBussiness 
 * 
 * Map<key,value>  value is ObjectBean  desc: key is "tableName" value is ObjectBean
 * 
 * eg:Map<"table_User",object> object.primaryKey = "77777777",object.Name="TomAndJerry",object.rule="1";...
 * 
 * return jsonStr --- > server convert to jsonObject 
 * 
 * server get the fixKey
 * 1:actionType
 * 2:map4TableBean
 */
function createRequestJSON_DataPackage(_ActionType,_Map4TableBean){
	
	var topestPackage = new Object();
	
	topestPackage._ActionType = _ActionType;
	
	topestPackage._Map4TableBean = _Map4TableBean;
	
	var finalJSONStr =  $.toJSON(topestPackage);
	
	return finalJSONStr; 
	
}
------------------------示例-------------------------------------------
var object_ResutJSONStrMessagePackage = new Object();
var object_ResutJSONStrMessagePackage = new Object();
object_ResutJSONStrMessagePackage.data = cutImageMessageDataPackage;
var strResult = $.toJSON(object_ResutJSONStrMessagePackage);


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值