index.js 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. "use strict";
  2. ///<reference path="index.d.ts"/>
  3. /**
  4. * 将sources合并到target,该合并全部是深拷贝
  5. * @param target
  6. * @param sources
  7. * @returns {Object}
  8. */
  9. Object.merge = function (target) {
  10. var sources = [];
  11. for (var _i = 1; _i < arguments.length; _i++) {
  12. sources[_i - 1] = arguments[_i];
  13. }
  14. for (var i = 0; i < sources.length; ++i) {
  15. var source = sources[i];
  16. if (typeof source != 'object' || source == null) {
  17. continue;
  18. }
  19. for (var skey in source) {
  20. //只处理自身的key 这里可能来自于外部prototype的扩展
  21. if (!source.hasOwnProperty(skey)) {
  22. continue;
  23. }
  24. if (source[skey] instanceof Date) {
  25. //Date类型 要克隆一份 保证深拷贝
  26. target[skey] = new Date(source[skey]);
  27. continue;
  28. }
  29. else if (typeof (target[skey]) == 'object' && target[skey] != null && typeof (source[skey]) == 'object' && source[skey] != null) {
  30. // 两个都是Object 递归merge之
  31. Object.merge(target[skey], source[skey]);
  32. }
  33. else {
  34. if (Array.isArray(source[skey])) {
  35. // 数组merge后还是数组
  36. target[skey] = Object.merge([], source[skey]);
  37. }
  38. else if (typeof (source[skey]) == 'object' && source[skey] !== null) {
  39. // Object要克隆一份以确保深拷贝
  40. target[skey] = Object.merge({}, source[skey]);
  41. }
  42. else {
  43. // 基本类型 直接赋值即可
  44. target[skey] = source[skey];
  45. }
  46. }
  47. }
  48. }
  49. return target;
  50. };
  51. if (!Object.values) {
  52. Object.values = function (obj) {
  53. var output = [];
  54. for (var k in obj) {
  55. obj.hasOwnProperty(k) && output.push(obj[k]);
  56. }
  57. return output;
  58. };
  59. }
  60. if (!Object.entries) {
  61. Object.entries = function (obj) {
  62. var output = [];
  63. for (var key in obj) {
  64. if (!obj.hasOwnProperty(key)) {
  65. continue;
  66. }
  67. output.push([key, obj[key]]);
  68. }
  69. return output;
  70. };
  71. }
  72. Object.forEach = function (obj, handler) {
  73. for (var key in obj) {
  74. if (!obj.hasOwnProperty(key)) {
  75. return;
  76. }
  77. handler(obj[key], key, obj);
  78. }
  79. };