vueComponent.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import { defineComponent } from 'vue';
  2. import _ from 'lodash';
  3. export default function(componentClass) {
  4. const comp = {};
  5. const obj = new componentClass();
  6. //data, options, props
  7. const data = {};
  8. for (const prop of Object.getOwnPropertyNames(obj)) {
  9. if (['_options', '_props'].includes(prop)) {//meta props
  10. if (prop === '_options') {
  11. const options = obj[prop];
  12. for (const optName of ['components', 'watch', 'emits']) {
  13. if (options[optName]) {
  14. comp[optName] = options[optName];
  15. }
  16. }
  17. } else if (prop === '_props') {
  18. comp.props = obj[prop];
  19. }
  20. } else {//usual prop
  21. data[prop] = obj[prop];
  22. }
  23. }
  24. comp.data = () => _.cloneDeep(data);
  25. //methods
  26. const methods = {};
  27. const computed = {};
  28. let classProto = Object.getPrototypeOf(obj);
  29. while (classProto) {
  30. const classMethods = Object.getOwnPropertyNames(classProto);
  31. for (const method of classMethods) {
  32. const desc = Object.getOwnPropertyDescriptor(classProto, method);
  33. if (desc.get) {//has getter, computed
  34. if (!computed[method]) {
  35. computed[method] = {get: desc.get};
  36. if (desc.set)
  37. computed[method].set = desc.set;
  38. }
  39. } else if ( ['beforeCreate', 'created', 'beforeMount', 'mounted', 'beforeUpdate', 'updated', 'activated',
  40. 'deactivated', 'beforeUnmount', 'unmounted', 'errorCaptured', 'renderTracked', 'renderTriggered',
  41. 'setup'].includes(method) ) {//life cycle hooks
  42. if (!comp[method])
  43. comp[method] = obj[method];
  44. } else if (method !== 'constructor') {//usual
  45. if (!methods[method])
  46. methods[method] = obj[method];
  47. }
  48. }
  49. classProto = Object.getPrototypeOf(classProto);
  50. }
  51. comp.methods = methods;
  52. comp.computed = computed;
  53. //console.log(comp);
  54. return defineComponent(comp);
  55. }