做批量数据录入时须要对json内的数组进行增删改查操作,splice还是非常强大的记录一下用法。

var lang = ["php","java","javascript"]; 

//删除 
var removed = lang.splice(2,1); 
console.log(lang); //php,javascript 
//console.log(removed); //java ,返回删除的项 
//插入 
var insert = lang.splice(0,0,"asp"); //从第0个位置開始插入 
//alert(insert); //返回空数组 
console.log(lang); //asp,php,javascript 
//替换 
var replace = lang.splice(1,1,"c#","ruby"); //删除一项,插入两项 
//alert(lang); //asp,c#,ruby 

console.log(replace); //php,返回删除的项 

 

 

另外,json多项的增删改查也贴上。备用:

/**
 * Json对象操作,增删改查
 *
 * @author lellansin
 * @blog www.lellansin.com
 * @version 0.1
 * 
 * 解决一些常见的问题
 * get/set 解决获取和设置时。无节点中断的问题
 * create  能够创建多级节点,若存在则覆盖新值
 * delete  删除节点及其子节点
 * print_r 格式化输出对象(调试用)
 * 实例见底部
 */


function Json() {


}


/**
 * 获取Json对象中的某个节点
 * 比如:json.get(Data, 'country', 'province', 'city');
 * 结果则返回 Data['country']['province']['city']
 * 无则返回false
 */
Json.prototype.get = function(obj, key) {
  var args = this.get.arguments;
  var result = obj;


  for (var i = 1; i < args.length; i++) {
    result = result[args[i]];
    if (result === undefined) {
      return false;
    };
  };
  return result;
};


/**
 * 设置Json对象中的某个节点
 * 比如:obj.set(data, "ENTRY", "FA_TOKEN_INVALID", 1234);
 * 将 data['ENTRY']['FA_TOKEN_INVALID'] 设置为1234
 * 成功true, 失败false
 */
Json.prototype.set = function(obj, key) {
  var args = this.set.arguments;
  if (ergodic_set(obj, args, 1)) {
    return true;
  } else {
    return false;
  }
}


/**
 * 在Json对象中创建节点(若存在则覆盖值)
 * 比如:obj.create(data, 'add', 'hello', 'test', 120);
 * 加入 data['create']['hello']['test'] 节点并设置值为 120
 * 成功true, 失败false
 */
Json.prototype.create = function(obj, key) {
  var args = this.create.arguments;
  if (ergodic_create(obj, args, 1)) {
    return true;
  } else {
    return false;
  }
}


/**
 * 在Json对象中删除节点
 * 比如:obj.delete(prods, 'grade', 'math');
 * 成功true, 失败false
 */
Json.prototype.delete = function(obj, key) {
  var args = this.delete.arguments;
  if (ergodic_delete(obj, args, 1)) {
    return true;
  } else {
    return false;
  }
}


/**
 * 返回Json对象的字符串形式(封装 ECMAScript 库函数)
 */
Json.prototype.getStr = function(obj) {
  return JSON.stringify(obj);
}


/**
 * 解析字符串返回Json对象(封装 ECMAScript 库函数)
 */
Json.prototype.getJson = function(str) {
  return JSON.parse(str);
}


/**
 * 格式化输出Json对象
 */
Json.prototype.print_r = function(obj) {
  console.log("{")
  ergodic_print(obj, "");
  console.log("}")
}


function ergodic_print(obj, indentation) {
  var indent = " " + indentation;
  if (obj.constructor == Object) {
    for (var p in obj) {
      if (obj[p].constructor == Array || obj[p].constructor == Object) {
        console.log(indent + "[" + p + "] => " + typeof(obj) + "");
        console.log(indent + "{");
        ergodic_print(obj[p], indent);
        console.log(indent + "}");
      } else if (obj[p].constructor == String) {
        console.log(indent + "[" + p + "] => '" + obj[p] + "'");
      } else {
        console.log(indent + "[" + p + "] => " + obj[p] + "");
      }
    }
  }
}


function ergodic_set(obj, args, floor) {
  if (obj.constructor == Object) {
    for (var tmpKey in obj) {
      if (tmpKey == args[floor]) {
        if (floor < args.length - 2) {
          return ergodic_set(obj[tmpKey], args, floor + 1);
        } else {
          // 此时參数floor为倒数第二个。加1值为最后一个
          obj[tmpKey] = args[floor + 1];
          console.log("成功设置,返回true");
          return true;
        }
      }
    }
  }
}


function ergodic_create(obj, args, floor) {
  if (obj.constructor == Object) {
    for (var tmpKey in obj) {
      if (tmpKey == args[floor]) {
        if (floor < args.length - 2) {
          return ergodic_create(obj[tmpKey], args, floor + 1);
        } else {
          obj[tmpKey] = args[floor + 1];
          return true;
        }
      }
    }
  }
  // 节点不存在,创建新节点
  if (floor < args.length - 1) {
    var jsonstr = getJsonFormat(args[args.length - 1]);


    for (var i = args.length - 2; i > floor; i--) {
      jsonstr = '{"' + args[i] + '":' + jsonstr + '}';
    };


    // 使用eval解析第三方Json数据时。可能会运行恶意代码
    // var node = eval('(' + jsonstr + ')');
    var node = JSON.parse(jsonstr);
    obj[args[floor]] = node;
    return true;
  }
}


function ergodic_delete(obj, args, floor) {
  if (obj.constructor == Object) {
    for (var tmpKey in obj) {
      if (tmpKey == args[floor]) {
        if (floor < args.length - 1) {
          return ergodic_delete(obj[tmpKey], args, floor + 1);
        } else {
          delete obj[tmpKey];
          return true;
        }
      }
    }
  }
}




function getJsonFormat(param) {
  if (param.constructor == String) {
    return '"' + param + '"';
  } else {
    return param;
  }
}






/**
 * 使用实例
 */


var data = {};


var prods = {
  'name': 'Alan',
  'grade': {
    'Chinese': 120,
    'math': 130,
    'competition': {
      'NOI': 'First prize'
    }
  }
};
/*
var json = new Json();


console.log("获取Json中节点");
console.log(json.get(data)); 
console.log(json.create(data, "0",""));
console.log(json.set(data, "0", prods));
console.log(json.create(data, "1",""));
console.log(json.set(data, "1", prods));
console.log(json.create(data, "2",""));
console.log(json.set(data, "2", prods));
console.log(json.get(data)); 
json.print_r(data);*/
/*
console.log(json.get(data, "OK")); // 200
console.log(json.get(data, "ENTRY", "FA_TOKEN_INVALID")); // 1001
console.log(json.get(data, "TEST", "获取没有的节点")); // false 没有的节点返回 false


console.log("设置Json中节点");
console.log(json.set(data, "ENTRY", "FA_TOKEN_INVALID", 1234));   // true 设置成功
console.log(json.get(data, "ENTRY", "FA_TOKEN_INVALID"));  // 1234   获取刚设置的节点
console.log(json.set(data, "ENTRY", "測试设置没有的节点", 1234)); // false 设置失败


console.log("创建新的Json节点");
var prods = {
  'name': 'Alan',
  'grade': {
    'Chinese': 120,
    'math': 130,
    'competition': {
      'NOI': 'First prize'
    }
  }
};
console.log(json.create(prods, 'create', 'hello', 'test', 120)); // true
console.log(json.create(prods, 'create', 'hello', 'test2', '通过')); // true


console.log("格式化输出节点");
json.print_r(prods);


console.log("删除节点");
console.log(json.delete(prods, 'grade', 'math')); // true
console.log(json.delete(prods, 'grade', 'competition')); // true
console.log(json.delete(prods, 'grade', '删除没有的节点')); // false
json.print_r(prods);
*/