| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
- import _extends from "@babel/runtime/helpers/esm/extends";
- import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
- import { nextTick } from 'vue';
- import { getOptionProps } from './props-util';
- export default {
- methods: {
- setState: function setState() {
- var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
- var callback = arguments.length > 1 ? arguments[1] : undefined;
- var newState = typeof state === 'function' ? state(this.$data, this.$props) : state;
- if (this.getDerivedStateFromProps) {
- var s = this.getDerivedStateFromProps(getOptionProps(this), _objectSpread(_objectSpread({}, this.$data), newState));
- if (s === null) {
- return;
- } else {
- newState = _objectSpread(_objectSpread({}, newState), s || {});
- }
- }
- _extends(this.$data, newState);
- if (this._.isMounted) {
- this.$forceUpdate();
- }
- nextTick(function () {
- callback && callback();
- });
- },
- __emit: function __emit() {
- // 直接调用事件,底层组件不需要vueTool记录events
- var args = [].slice.call(arguments, 0);
- var eventName = args[0];
- eventName = "on".concat(eventName[0].toUpperCase()).concat(eventName.substring(1));
- var event = this.$props[eventName] || this.$attrs[eventName];
- if (args.length && event) {
- if (Array.isArray(event)) {
- for (var i = 0, l = event.length; i < l; i++) {
- event[i].apply(event, _toConsumableArray(args.slice(1)));
- }
- } else {
- event.apply(void 0, _toConsumableArray(args.slice(1)));
- }
- }
- }
- }
- };
|