张映 发表于 2014-02-10

分类目录: js/jquery

标签:json删除排序添加

js数据格式和json数据格式,各有各的用处,就个人而言,json更好用一点,js自身的数组和对像限制比较多。

以js的数组举例:

  1. var a = ['1'];
  2. a[5] = 52;
  3. a.length    //这儿的结果是6,也就是说,中间的key会自动补全,而值呢,是undefined

一,添加和删除

1,一维数组

  1. test = {};                      //空json对像
  2. test['firstname'] = "tank";     //添加二个元素
  3. test['lastname'] = "zhang";
  4. console.log(test);              //查看
  5. delete test['lastname'];        //删除json中的某个元素
  6. console.log(test);

2,二维数组

  1. test1 = [{"name":"tank","total":"100"},{"name":"zhang","total":"23"},{"name":"hao","total":"325"}];
  2. add = {"name":"may"};
  3. test1.push(add);              //添加一个元素
  4. console.log(test1);
  5. delete test1[2];              //删除一个元素
  6. console.log(test1);

二,排序

1,一维数组

  1. test = ["100","23","325"];           //定义个数组
  2. function sortNumber(a,b)             //定义排序方法
  3. {
  4. return a - b
  5. }
  6. test1_sort=test.sort(sortNumber);
  7. console.log(test1_sort);

2,二维数组

  1. test1 = [{"name":"tank","total":"100"},{"name":"zhang","total":"23"},{"name":"hao","total":"325"}];
  2. sort_by = function(field, reverse, primer){         //定义排序方法
  3. var key = primer ?
  4. function(x) {return primer(x[field])} :
  5. function(x) {return x[field]};
  6. reverse = [-1, 1][+!!reverse];
  7. return function (a, b) {
  8. return a = key(a), b = key(b), reverse * ((a > b) - (b > a));
  9. }
  10. }
  11. test1_sort=test1.sort(sort_by('total', true, parseInt));    //根据total,升序排
  12. console.log(test1_sort);
  13. test1_sort=test1.sort(sort_by('name', false, ''));          //根据name,倒序排
  14. console.log(test1_sort);

别看是小问题,但是如果长时间不用,也会生疏,或者忘了。

05-11 17:01
查看更多