model_base.ts 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. // 用于将属性名添加到对应类的可保存属性数组中的函数
  2. export function save(target: any, keyName: string) {
  3. // 获取目标类对应的可保存属性数组
  4. let arr = getOrCreateClassArray(target.constructor);
  5. // 将属性名添加到数组中
  6. arr.push(keyName);
  7. }
  8. // 获取目标类对应的可保存属性数组,如果不存在则创建一个新的空数组并设置到classMap中
  9. function getOrCreateClassArray(constructor: Function): any[] {
  10. let arr = model_base.classMap.get(constructor);
  11. if (arr === undefined) {
  12. arr = [];
  13. model_base.classMap.set(constructor, arr);
  14. }
  15. return arr;
  16. }
  17. export default class model_base {
  18. public static classMap: Map<Function, any[]> = new Map();
  19. // 获取当前对象可保存属性的数据并返回一个包含这些数据的对象的函数
  20. public getData(): object {
  21. let data = {};
  22. // 获取当前类的可保存属性数组
  23. let savepars = this.getSaveParamsForClass(this.constructor);
  24. // 遍历可保存属性数组,将对应属性的值添加到返回数据对象中
  25. for (let i = 0; i < savepars.length; ++i) {
  26. data[savepars[i]] = this[savepars[i]];
  27. }
  28. return data;
  29. }
  30. // 根据传入的数据设置当前对象可保存属性的值的函数
  31. public setData(data: any) {
  32. // 如果传入数据为空,直接返回
  33. if (!data) return;
  34. // 获取当前类的可保存属性数组
  35. let savepars = this.getSaveParamsForClass(this.constructor);
  36. // 遍历可保存属性数组,根据数据设置对应属性的值
  37. for (let i = 0; i < savepars.length; ++i) {
  38. const element = data[savepars[i]];
  39. if (element != null || element != undefined) {
  40. if (Object.prototype.toString.call(element) == "[object Object]") {
  41. // 如果元素是对象,遍历对象的属性并设置到当前对象的对应属性中
  42. for (const key in element) {
  43. this[savepars[i]][key] = element[key];
  44. }
  45. } else {
  46. // 如果元素不是对象,直接设置到当前对象的对应属性中
  47. this[savepars[i]] = element;
  48. }
  49. }
  50. }
  51. }
  52. // 获取指定类的可保存属性数组的函数
  53. private getSaveParamsForClass(constructor: Function): any[] {
  54. return model_base.classMap.get(constructor) || [];
  55. }
  56. }