BaseMixin.js 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
  2. import _extends from "@babel/runtime/helpers/esm/extends";
  3. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  4. import { nextTick } from 'vue';
  5. import { getOptionProps } from './props-util';
  6. export default {
  7. methods: {
  8. setState: function setState() {
  9. var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
  10. var callback = arguments.length > 1 ? arguments[1] : undefined;
  11. var newState = typeof state === 'function' ? state(this.$data, this.$props) : state;
  12. if (this.getDerivedStateFromProps) {
  13. var s = this.getDerivedStateFromProps(getOptionProps(this), _objectSpread(_objectSpread({}, this.$data), newState));
  14. if (s === null) {
  15. return;
  16. } else {
  17. newState = _objectSpread(_objectSpread({}, newState), s || {});
  18. }
  19. }
  20. _extends(this.$data, newState);
  21. if (this._.isMounted) {
  22. this.$forceUpdate();
  23. }
  24. nextTick(function () {
  25. callback && callback();
  26. });
  27. },
  28. __emit: function __emit() {
  29. // 直接调用事件,底层组件不需要vueTool记录events
  30. var args = [].slice.call(arguments, 0);
  31. var eventName = args[0];
  32. eventName = "on".concat(eventName[0].toUpperCase()).concat(eventName.substring(1));
  33. var event = this.$props[eventName] || this.$attrs[eventName];
  34. if (args.length && event) {
  35. if (Array.isArray(event)) {
  36. for (var i = 0, l = event.length; i < l; i++) {
  37. event[i].apply(event, _toConsumableArray(args.slice(1)));
  38. }
  39. } else {
  40. event.apply(void 0, _toConsumableArray(args.slice(1)));
  41. }
  42. }
  43. }
  44. }
  45. };