(global["webpackJsonp"] = global["webpackJsonp"] || []).push([["common/vendor"],{ /***/ 1: /*!************************************************************!*\ !*** ./node_modules/@dcloudio/uni-mp-weixin/dist/index.js ***! \************************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; /* WEBPACK VAR INJECTION */(function(global) {Object.defineProperty(exports, "__esModule", { value: true });exports.createApp = createApp;exports.createComponent = createComponent;exports.createPage = createPage;exports.createPlugin = createPlugin;exports.createSubpackageApp = createSubpackageApp;exports.default = void 0;var _vue = _interopRequireDefault(__webpack_require__(/*! vue */ 3)); var _uniI18n = __webpack_require__(/*! @dcloudio/uni-i18n */ 4);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { default: obj };}function ownKeys(object, enumerableOnly) {var keys = Object.keys(object);if (Object.getOwnPropertySymbols) {var symbols = Object.getOwnPropertySymbols(object);if (enumerableOnly) symbols = symbols.filter(function (sym) {return Object.getOwnPropertyDescriptor(object, sym).enumerable;});keys.push.apply(keys, symbols);}return keys;}function _objectSpread(target) {for (var i = 1; i < arguments.length; i++) {var source = arguments[i] != null ? arguments[i] : {};if (i % 2) {ownKeys(Object(source), true).forEach(function (key) {_defineProperty(target, key, source[key]);});} else if (Object.getOwnPropertyDescriptors) {Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));} else {ownKeys(Object(source)).forEach(function (key) {Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));});}}return target;}function _slicedToArray(arr, i) {return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();}function _nonIterableRest() {throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function _iterableToArrayLimit(arr, i) {if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return;var _arr = [];var _n = true;var _d = false;var _e = undefined;try {for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {_arr.push(_s.value);if (i && _arr.length === i) break;}} catch (err) {_d = true;_e = err;} finally {try {if (!_n && _i["return"] != null) _i["return"]();} finally {if (_d) throw _e;}}return _arr;}function _arrayWithHoles(arr) {if (Array.isArray(arr)) return arr;}function _defineProperty(obj, key, value) {if (key in obj) {Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true });} else {obj[key] = value;}return obj;}function _toConsumableArray(arr) {return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();}function _nonIterableSpread() {throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");}function _unsupportedIterableToArray(o, minLen) {if (!o) return;if (typeof o === "string") return _arrayLikeToArray(o, minLen);var n = Object.prototype.toString.call(o).slice(8, -1);if (n === "Object" && o.constructor) n = o.constructor.name;if (n === "Map" || n === "Set") return Array.from(o);if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);}function _iterableToArray(iter) {if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter);}function _arrayWithoutHoles(arr) {if (Array.isArray(arr)) return _arrayLikeToArray(arr);}function _arrayLikeToArray(arr, len) {if (len == null || len > arr.length) len = arr.length;for (var i = 0, arr2 = new Array(len); i < len; i++) {arr2[i] = arr[i];}return arr2;} var realAtob; var b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='; var b64re = /^(?:[A-Za-z\d+/]{4})*?(?:[A-Za-z\d+/]{2}(?:==)?|[A-Za-z\d+/]{3}=?)?$/; if (typeof atob !== 'function') { realAtob = function realAtob(str) { str = String(str).replace(/[\t\n\f\r ]+/g, ''); if (!b64re.test(str)) {throw new Error("Failed to execute 'atob' on 'Window': The string to be decoded is not correctly encoded.");} // Adding the padding if missing, for semplicity str += '=='.slice(2 - (str.length & 3)); var bitmap;var result = '';var r1;var r2;var i = 0; for (; i < str.length;) { bitmap = b64.indexOf(str.charAt(i++)) << 18 | b64.indexOf(str.charAt(i++)) << 12 | (r1 = b64.indexOf(str.charAt(i++))) << 6 | (r2 = b64.indexOf(str.charAt(i++))); result += r1 === 64 ? String.fromCharCode(bitmap >> 16 & 255) : r2 === 64 ? String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255) : String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255, bitmap & 255); } return result; }; } else { // 注意atob只能在全局对象上调用,例如:`const Base64 = {atob};Base64.atob('xxxx')`是错误的用法 realAtob = atob; } function b64DecodeUnicode(str) { return decodeURIComponent(realAtob(str).split('').map(function (c) { return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2); }).join('')); } function getCurrentUserInfo() { var token = wx.getStorageSync('uni_id_token') || ''; var tokenArr = token.split('.'); if (!token || tokenArr.length !== 3) { return { uid: null, role: [], permission: [], tokenExpired: 0 }; } var userInfo; try { userInfo = JSON.parse(b64DecodeUnicode(tokenArr[1])); } catch (error) { throw new Error('获取当前用户信息出错,详细错误信息为:' + error.message); } userInfo.tokenExpired = userInfo.exp * 1000; delete userInfo.exp; delete userInfo.iat; return userInfo; } function uniIdMixin(Vue) { Vue.prototype.uniIDHasRole = function (roleId) {var _getCurrentUserInfo = getCurrentUserInfo(),role = _getCurrentUserInfo.role; return role.indexOf(roleId) > -1; }; Vue.prototype.uniIDHasPermission = function (permissionId) {var _getCurrentUserInfo2 = getCurrentUserInfo(),permission = _getCurrentUserInfo2.permission; return this.uniIDHasRole('admin') || permission.indexOf(permissionId) > -1; }; Vue.prototype.uniIDTokenValid = function () {var _getCurrentUserInfo3 = getCurrentUserInfo(),tokenExpired = _getCurrentUserInfo3.tokenExpired; return tokenExpired > Date.now(); }; } var _toString = Object.prototype.toString; var hasOwnProperty = Object.prototype.hasOwnProperty; function isFn(fn) { return typeof fn === 'function'; } function isStr(str) { return typeof str === 'string'; } function isPlainObject(obj) { return _toString.call(obj) === '[object Object]'; } function hasOwn(obj, key) { return hasOwnProperty.call(obj, key); } function noop() {} /** * Create a cached version of a pure function. */ function cached(fn) { var cache = Object.create(null); return function cachedFn(str) { var hit = cache[str]; return hit || (cache[str] = fn(str)); }; } /** * Camelize a hyphen-delimited string. */ var camelizeRE = /-(\w)/g; var camelize = cached(function (str) { return str.replace(camelizeRE, function (_, c) {return c ? c.toUpperCase() : '';}); }); var HOOKS = [ 'invoke', 'success', 'fail', 'complete', 'returnValue']; var globalInterceptors = {}; var scopedInterceptors = {}; function mergeHook(parentVal, childVal) { var res = childVal ? parentVal ? parentVal.concat(childVal) : Array.isArray(childVal) ? childVal : [childVal] : parentVal; return res ? dedupeHooks(res) : res; } function dedupeHooks(hooks) { var res = []; for (var i = 0; i < hooks.length; i++) { if (res.indexOf(hooks[i]) === -1) { res.push(hooks[i]); } } return res; } function removeHook(hooks, hook) { var index = hooks.indexOf(hook); if (index !== -1) { hooks.splice(index, 1); } } function mergeInterceptorHook(interceptor, option) { Object.keys(option).forEach(function (hook) { if (HOOKS.indexOf(hook) !== -1 && isFn(option[hook])) { interceptor[hook] = mergeHook(interceptor[hook], option[hook]); } }); } function removeInterceptorHook(interceptor, option) { if (!interceptor || !option) { return; } Object.keys(option).forEach(function (hook) { if (HOOKS.indexOf(hook) !== -1 && isFn(option[hook])) { removeHook(interceptor[hook], option[hook]); } }); } function addInterceptor(method, option) { if (typeof method === 'string' && isPlainObject(option)) { mergeInterceptorHook(scopedInterceptors[method] || (scopedInterceptors[method] = {}), option); } else if (isPlainObject(method)) { mergeInterceptorHook(globalInterceptors, method); } } function removeInterceptor(method, option) { if (typeof method === 'string') { if (isPlainObject(option)) { removeInterceptorHook(scopedInterceptors[method], option); } else { delete scopedInterceptors[method]; } } else if (isPlainObject(method)) { removeInterceptorHook(globalInterceptors, method); } } function wrapperHook(hook) { return function (data) { return hook(data) || data; }; } function isPromise(obj) { return !!obj && (typeof obj === 'object' || typeof obj === 'function') && typeof obj.then === 'function'; } function queue(hooks, data) { var promise = false; for (var i = 0; i < hooks.length; i++) { var hook = hooks[i]; if (promise) { promise = Promise.resolve(wrapperHook(hook)); } else { var res = hook(data); if (isPromise(res)) { promise = Promise.resolve(res); } if (res === false) { return { then: function then() {} }; } } } return promise || { then: function then(callback) { return callback(data); } }; } function wrapperOptions(interceptor) {var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; ['success', 'fail', 'complete'].forEach(function (name) { if (Array.isArray(interceptor[name])) { var oldCallback = options[name]; options[name] = function callbackInterceptor(res) { queue(interceptor[name], res).then(function (res) { /* eslint-disable no-mixed-operators */ return isFn(oldCallback) && oldCallback(res) || res; }); }; } }); return options; } function wrapperReturnValue(method, returnValue) { var returnValueHooks = []; if (Array.isArray(globalInterceptors.returnValue)) { returnValueHooks.push.apply(returnValueHooks, _toConsumableArray(globalInterceptors.returnValue)); } var interceptor = scopedInterceptors[method]; if (interceptor && Array.isArray(interceptor.returnValue)) { returnValueHooks.push.apply(returnValueHooks, _toConsumableArray(interceptor.returnValue)); } returnValueHooks.forEach(function (hook) { returnValue = hook(returnValue) || returnValue; }); return returnValue; } function getApiInterceptorHooks(method) { var interceptor = Object.create(null); Object.keys(globalInterceptors).forEach(function (hook) { if (hook !== 'returnValue') { interceptor[hook] = globalInterceptors[hook].slice(); } }); var scopedInterceptor = scopedInterceptors[method]; if (scopedInterceptor) { Object.keys(scopedInterceptor).forEach(function (hook) { if (hook !== 'returnValue') { interceptor[hook] = (interceptor[hook] || []).concat(scopedInterceptor[hook]); } }); } return interceptor; } function invokeApi(method, api, options) {for (var _len = arguments.length, params = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {params[_key - 3] = arguments[_key];} var interceptor = getApiInterceptorHooks(method); if (interceptor && Object.keys(interceptor).length) { if (Array.isArray(interceptor.invoke)) { var res = queue(interceptor.invoke, options); return res.then(function (options) { return api.apply(void 0, [wrapperOptions(interceptor, options)].concat(params)); }); } else { return api.apply(void 0, [wrapperOptions(interceptor, options)].concat(params)); } } return api.apply(void 0, [options].concat(params)); } var promiseInterceptor = { returnValue: function returnValue(res) { if (!isPromise(res)) { return res; } return new Promise(function (resolve, reject) { res.then(function (res) { if (res[0]) { reject(res[0]); } else { resolve(res[1]); } }); }); } }; var SYNC_API_RE = /^\$|Window$|WindowStyle$|sendHostEvent|sendNativeEvent|restoreGlobal|requireGlobal|getCurrentSubNVue|getMenuButtonBoundingClientRect|^report|interceptors|Interceptor$|getSubNVueById|requireNativePlugin|upx2px|hideKeyboard|canIUse|^create|Sync$|Manager$|base64ToArrayBuffer|arrayBufferToBase64|getLocale|setLocale/; var CONTEXT_API_RE = /^create|Manager$/; // Context例外情况 var CONTEXT_API_RE_EXC = ['createBLEConnection']; // 同步例外情况 var ASYNC_API = ['createBLEConnection']; var CALLBACK_API_RE = /^on|^off/; function isContextApi(name) { return CONTEXT_API_RE.test(name) && CONTEXT_API_RE_EXC.indexOf(name) === -1; } function isSyncApi(name) { return SYNC_API_RE.test(name) && ASYNC_API.indexOf(name) === -1; } function isCallbackApi(name) { return CALLBACK_API_RE.test(name) && name !== 'onPush'; } function handlePromise(promise) { return promise.then(function (data) { return [null, data]; }). catch(function (err) {return [err];}); } function shouldPromise(name) { if ( isContextApi(name) || isSyncApi(name) || isCallbackApi(name)) { return false; } return true; } /* eslint-disable no-extend-native */ if (!Promise.prototype.finally) { Promise.prototype.finally = function (callback) { var promise = this.constructor; return this.then( function (value) {return promise.resolve(callback()).then(function () {return value;});}, function (reason) {return promise.resolve(callback()).then(function () { throw reason; });}); }; } function promisify(name, api) { if (!shouldPromise(name)) { return api; } return function promiseApi() {var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};for (var _len2 = arguments.length, params = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {params[_key2 - 1] = arguments[_key2];} if (isFn(options.success) || isFn(options.fail) || isFn(options.complete)) { return wrapperReturnValue(name, invokeApi.apply(void 0, [name, api, options].concat(params))); } return wrapperReturnValue(name, handlePromise(new Promise(function (resolve, reject) { invokeApi.apply(void 0, [name, api, Object.assign({}, options, { success: resolve, fail: reject })].concat( params)); }))); }; } var EPS = 1e-4; var BASE_DEVICE_WIDTH = 750; var isIOS = false; var deviceWidth = 0; var deviceDPR = 0; function checkDeviceWidth() {var _wx$getSystemInfoSync = wx.getSystemInfoSync(),platform = _wx$getSystemInfoSync.platform,pixelRatio = _wx$getSystemInfoSync.pixelRatio,windowWidth = _wx$getSystemInfoSync.windowWidth; // uni=>wx runtime 编译目标是 uni 对象,内部不允许直接使用 uni deviceWidth = windowWidth; deviceDPR = pixelRatio; isIOS = platform === 'ios'; } function upx2px(number, newDeviceWidth) { if (deviceWidth === 0) { checkDeviceWidth(); } number = Number(number); if (number === 0) { return 0; } var result = number / BASE_DEVICE_WIDTH * (newDeviceWidth || deviceWidth); if (result < 0) { result = -result; } result = Math.floor(result + EPS); if (result === 0) { if (deviceDPR === 1 || !isIOS) { result = 1; } else { result = 0.5; } } return number < 0 ? -result : result; } function getLocale() { // 优先使用 $locale var app = getApp({ allowDefault: true }); if (app && app.$vm) { return app.$vm.$locale; } return wx.getSystemInfoSync().language || 'zh-Hans'; } function setLocale(locale) { var app = getApp(); if (!app) { return false; } var oldLocale = app.$vm.$locale; if (oldLocale !== locale) { app.$vm.$locale = locale; onLocaleChangeCallbacks.forEach(function (fn) {return fn({ locale: locale });}); return true; } return false; } var onLocaleChangeCallbacks = []; function onLocaleChange(fn) { if (onLocaleChangeCallbacks.indexOf(fn) === -1) { onLocaleChangeCallbacks.push(fn); } } if (typeof global !== 'undefined') { global.getLocale = getLocale; } var interceptors = { promiseInterceptor: promiseInterceptor }; var baseApi = /*#__PURE__*/Object.freeze({ __proto__: null, upx2px: upx2px, getLocale: getLocale, setLocale: setLocale, onLocaleChange: onLocaleChange, addInterceptor: addInterceptor, removeInterceptor: removeInterceptor, interceptors: interceptors }); function findExistsPageIndex(url) { var pages = getCurrentPages(); var len = pages.length; while (len--) { var page = pages[len]; if (page.$page && page.$page.fullPath === url) { return len; } } return -1; } var redirectTo = { name: function name(fromArgs) { if (fromArgs.exists === 'back' && fromArgs.delta) { return 'navigateBack'; } return 'redirectTo'; }, args: function args(fromArgs) { if (fromArgs.exists === 'back' && fromArgs.url) { var existsPageIndex = findExistsPageIndex(fromArgs.url); if (existsPageIndex !== -1) { var delta = getCurrentPages().length - 1 - existsPageIndex; if (delta > 0) { fromArgs.delta = delta; } } } } }; var previewImage = { args: function args(fromArgs) { var currentIndex = parseInt(fromArgs.current); if (isNaN(currentIndex)) { return; } var urls = fromArgs.urls; if (!Array.isArray(urls)) { return; } var len = urls.length; if (!len) { return; } if (currentIndex < 0) { currentIndex = 0; } else if (currentIndex >= len) { currentIndex = len - 1; } if (currentIndex > 0) { fromArgs.current = urls[currentIndex]; fromArgs.urls = urls.filter( function (item, index) {return index < currentIndex ? item !== urls[currentIndex] : true;}); } else { fromArgs.current = urls[0]; } return { indicator: false, loop: false }; } }; var UUID_KEY = '__DC_STAT_UUID'; var deviceId; function addUuid(result) { deviceId = deviceId || wx.getStorageSync(UUID_KEY); if (!deviceId) { deviceId = Date.now() + '' + Math.floor(Math.random() * 1e7); wx.setStorage({ key: UUID_KEY, data: deviceId }); } result.deviceId = deviceId; } function addSafeAreaInsets(result) { if (result.safeArea) { var safeArea = result.safeArea; result.safeAreaInsets = { top: safeArea.top, left: safeArea.left, right: result.windowWidth - safeArea.right, bottom: result.windowHeight - safeArea.bottom }; } } var getSystemInfo = { returnValue: function returnValue(result) { addUuid(result); addSafeAreaInsets(result); } }; var showActionSheet = { args: function args(fromArgs) { if (typeof fromArgs === 'object') { fromArgs.alertText = fromArgs.title; } } }; // import navigateTo from 'uni-helpers/navigate-to' var protocols = { redirectTo: redirectTo, // navigateTo, // 由于在微信开发者工具的页面参数,会显示__id__参数,因此暂时关闭mp-weixin对于navigateTo的AOP previewImage: previewImage, getSystemInfo: getSystemInfo, getSystemInfoSync: getSystemInfo, showActionSheet: showActionSheet }; var todos = [ 'vibrate', 'preloadPage', 'unPreloadPage', 'loadSubPackage']; var canIUses = []; var CALLBACKS = ['success', 'fail', 'cancel', 'complete']; function processCallback(methodName, method, returnValue) { return function (res) { return method(processReturnValue(methodName, res, returnValue)); }; } function processArgs(methodName, fromArgs) {var argsOption = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};var returnValue = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};var keepFromArgs = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; if (isPlainObject(fromArgs)) {// 一般 api 的参数解析 var toArgs = keepFromArgs === true ? fromArgs : {}; // returnValue 为 false 时,说明是格式化返回值,直接在返回值对象上修改赋值 if (isFn(argsOption)) { argsOption = argsOption(fromArgs, toArgs) || {}; } for (var key in fromArgs) { if (hasOwn(argsOption, key)) { var keyOption = argsOption[key]; if (isFn(keyOption)) { keyOption = keyOption(fromArgs[key], fromArgs, toArgs); } if (!keyOption) {// 不支持的参数 console.warn("The '".concat(methodName, "' method of platform '\u5FAE\u4FE1\u5C0F\u7A0B\u5E8F' does not support option '").concat(key, "'")); } else if (isStr(keyOption)) {// 重写参数 key toArgs[keyOption] = fromArgs[key]; } else if (isPlainObject(keyOption)) {// {name:newName,value:value}可重新指定参数 key:value toArgs[keyOption.name ? keyOption.name : key] = keyOption.value; } } else if (CALLBACKS.indexOf(key) !== -1) { if (isFn(fromArgs[key])) { toArgs[key] = processCallback(methodName, fromArgs[key], returnValue); } } else { if (!keepFromArgs) { toArgs[key] = fromArgs[key]; } } } return toArgs; } else if (isFn(fromArgs)) { fromArgs = processCallback(methodName, fromArgs, returnValue); } return fromArgs; } function processReturnValue(methodName, res, returnValue) {var keepReturnValue = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; if (isFn(protocols.returnValue)) {// 处理通用 returnValue res = protocols.returnValue(methodName, res); } return processArgs(methodName, res, returnValue, {}, keepReturnValue); } function wrapper(methodName, method) { if (hasOwn(protocols, methodName)) { var protocol = protocols[methodName]; if (!protocol) {// 暂不支持的 api return function () { console.error("Platform '\u5FAE\u4FE1\u5C0F\u7A0B\u5E8F' does not support '".concat(methodName, "'.")); }; } return function (arg1, arg2) {// 目前 api 最多两个参数 var options = protocol; if (isFn(protocol)) { options = protocol(arg1); } arg1 = processArgs(methodName, arg1, options.args, options.returnValue); var args = [arg1]; if (typeof arg2 !== 'undefined') { args.push(arg2); } if (isFn(options.name)) { methodName = options.name(arg1); } else if (isStr(options.name)) { methodName = options.name; } var returnValue = wx[methodName].apply(wx, args); if (isSyncApi(methodName)) {// 同步 api return processReturnValue(methodName, returnValue, options.returnValue, isContextApi(methodName)); } return returnValue; }; } return method; } var todoApis = Object.create(null); var TODOS = [ 'onTabBarMidButtonTap', 'subscribePush', 'unsubscribePush', 'onPush', 'offPush', 'share']; function createTodoApi(name) { return function todoApi(_ref) {var fail = _ref.fail,complete = _ref.complete; var res = { errMsg: "".concat(name, ":fail method '").concat(name, "' not supported") }; isFn(fail) && fail(res); isFn(complete) && complete(res); }; } TODOS.forEach(function (name) { todoApis[name] = createTodoApi(name); }); var providers = { oauth: ['weixin'], share: ['weixin'], payment: ['wxpay'], push: ['weixin'] }; function getProvider(_ref2) {var service = _ref2.service,success = _ref2.success,fail = _ref2.fail,complete = _ref2.complete; var res = false; if (providers[service]) { res = { errMsg: 'getProvider:ok', service: service, provider: providers[service] }; isFn(success) && success(res); } else { res = { errMsg: 'getProvider:fail service not found' }; isFn(fail) && fail(res); } isFn(complete) && complete(res); } var extraApi = /*#__PURE__*/Object.freeze({ __proto__: null, getProvider: getProvider }); var getEmitter = function () { var Emitter; return function getUniEmitter() { if (!Emitter) { Emitter = new _vue.default(); } return Emitter; }; }(); function apply(ctx, method, args) { return ctx[method].apply(ctx, args); } function $on() { return apply(getEmitter(), '$on', Array.prototype.slice.call(arguments)); } function $off() { return apply(getEmitter(), '$off', Array.prototype.slice.call(arguments)); } function $once() { return apply(getEmitter(), '$once', Array.prototype.slice.call(arguments)); } function $emit() { return apply(getEmitter(), '$emit', Array.prototype.slice.call(arguments)); } var eventApi = /*#__PURE__*/Object.freeze({ __proto__: null, $on: $on, $off: $off, $once: $once, $emit: $emit }); var api = /*#__PURE__*/Object.freeze({ __proto__: null }); var MPPage = Page; var MPComponent = Component; var customizeRE = /:/g; var customize = cached(function (str) { return camelize(str.replace(customizeRE, '-')); }); function initTriggerEvent(mpInstance) { var oldTriggerEvent = mpInstance.triggerEvent; var newTriggerEvent = function newTriggerEvent(event) {for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {args[_key3 - 1] = arguments[_key3];} return oldTriggerEvent.apply(mpInstance, [customize(event)].concat(args)); }; try { // 京东小程序 triggerEvent 为只读 mpInstance.triggerEvent = newTriggerEvent; } catch (error) { mpInstance._triggerEvent = newTriggerEvent; } } function initHook(name, options, isComponent) { var oldHook = options[name]; if (!oldHook) { options[name] = function () { initTriggerEvent(this); }; } else { options[name] = function () { initTriggerEvent(this);for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {args[_key4] = arguments[_key4];} return oldHook.apply(this, args); }; } } if (!MPPage.__$wrappered) { MPPage.__$wrappered = true; Page = function Page() {var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; initHook('onLoad', options); return MPPage(options); }; Page.after = MPPage.after; Component = function Component() {var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; initHook('created', options); return MPComponent(options); }; } var PAGE_EVENT_HOOKS = [ 'onPullDownRefresh', 'onReachBottom', 'onAddToFavorites', 'onShareTimeline', 'onShareAppMessage', 'onPageScroll', 'onResize', 'onTabItemTap']; function initMocks(vm, mocks) { var mpInstance = vm.$mp[vm.mpType]; mocks.forEach(function (mock) { if (hasOwn(mpInstance, mock)) { vm[mock] = mpInstance[mock]; } }); } function hasHook(hook, vueOptions) { if (!vueOptions) { return true; } if (_vue.default.options && Array.isArray(_vue.default.options[hook])) { return true; } vueOptions = vueOptions.default || vueOptions; if (isFn(vueOptions)) { if (isFn(vueOptions.extendOptions[hook])) { return true; } if (vueOptions.super && vueOptions.super.options && Array.isArray(vueOptions.super.options[hook])) { return true; } return false; } if (isFn(vueOptions[hook])) { return true; } var mixins = vueOptions.mixins; if (Array.isArray(mixins)) { return !!mixins.find(function (mixin) {return hasHook(hook, mixin);}); } } function initHooks(mpOptions, hooks, vueOptions) { hooks.forEach(function (hook) { if (hasHook(hook, vueOptions)) { mpOptions[hook] = function (args) { return this.$vm && this.$vm.__call_hook(hook, args); }; } }); } function initVueComponent(Vue, vueOptions) { vueOptions = vueOptions.default || vueOptions; var VueComponent; if (isFn(vueOptions)) { VueComponent = vueOptions; } else { VueComponent = Vue.extend(vueOptions); } vueOptions = VueComponent.options; return [VueComponent, vueOptions]; } function initSlots(vm, vueSlots) { if (Array.isArray(vueSlots) && vueSlots.length) { var $slots = Object.create(null); vueSlots.forEach(function (slotName) { $slots[slotName] = true; }); vm.$scopedSlots = vm.$slots = $slots; } } function initVueIds(vueIds, mpInstance) { vueIds = (vueIds || '').split(','); var len = vueIds.length; if (len === 1) { mpInstance._$vueId = vueIds[0]; } else if (len === 2) { mpInstance._$vueId = vueIds[0]; mpInstance._$vuePid = vueIds[1]; } } function initData(vueOptions, context) { var data = vueOptions.data || {}; var methods = vueOptions.methods || {}; if (typeof data === 'function') { try { data = data.call(context); // 支持 Vue.prototype 上挂的数据 } catch (e) { if (Object({"VUE_APP_NAME":"dx","VUE_APP_PLATFORM":"mp-weixin","NODE_ENV":"development","BASE_URL":"/"}).VUE_APP_DEBUG) { console.warn('根据 Vue 的 data 函数初始化小程序 data 失败,请尽量确保 data 函数中不访问 vm 对象,否则可能影响首次数据渲染速度。', data); } } } else { try { // 对 data 格式化 data = JSON.parse(JSON.stringify(data)); } catch (e) {} } if (!isPlainObject(data)) { data = {}; } Object.keys(methods).forEach(function (methodName) { if (context.__lifecycle_hooks__.indexOf(methodName) === -1 && !hasOwn(data, methodName)) { data[methodName] = methods[methodName]; } }); return data; } var PROP_TYPES = [String, Number, Boolean, Object, Array, null]; function createObserver(name) { return function observer(newVal, oldVal) { if (this.$vm) { this.$vm[name] = newVal; // 为了触发其他非 render watcher } }; } function initBehaviors(vueOptions, initBehavior) { var vueBehaviors = vueOptions.behaviors; var vueExtends = vueOptions.extends; var vueMixins = vueOptions.mixins; var vueProps = vueOptions.props; if (!vueProps) { vueOptions.props = vueProps = []; } var behaviors = []; if (Array.isArray(vueBehaviors)) { vueBehaviors.forEach(function (behavior) { behaviors.push(behavior.replace('uni://', "wx".concat("://"))); if (behavior === 'uni://form-field') { if (Array.isArray(vueProps)) { vueProps.push('name'); vueProps.push('value'); } else { vueProps.name = { type: String, default: '' }; vueProps.value = { type: [String, Number, Boolean, Array, Object, Date], default: '' }; } } }); } if (isPlainObject(vueExtends) && vueExtends.props) { behaviors.push( initBehavior({ properties: initProperties(vueExtends.props, true) })); } if (Array.isArray(vueMixins)) { vueMixins.forEach(function (vueMixin) { if (isPlainObject(vueMixin) && vueMixin.props) { behaviors.push( initBehavior({ properties: initProperties(vueMixin.props, true) })); } }); } return behaviors; } function parsePropType(key, type, defaultValue, file) { // [String]=>String if (Array.isArray(type) && type.length === 1) { return type[0]; } return type; } function initProperties(props) {var isBehavior = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;var file = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : ''; var properties = {}; if (!isBehavior) { properties.vueId = { type: String, value: '' }; // 用于字节跳动小程序模拟抽象节点 properties.generic = { type: Object, value: null }; // scopedSlotsCompiler auto properties.scopedSlotsCompiler = { type: String, value: '' }; properties.vueSlots = { // 小程序不能直接定义 $slots 的 props,所以通过 vueSlots 转换到 $slots type: null, value: [], observer: function observer(newVal, oldVal) { var $slots = Object.create(null); newVal.forEach(function (slotName) { $slots[slotName] = true; }); this.setData({ $slots: $slots }); } }; } if (Array.isArray(props)) {// ['title'] props.forEach(function (key) { properties[key] = { type: null, observer: createObserver(key) }; }); } else if (isPlainObject(props)) {// {title:{type:String,default:''},content:String} Object.keys(props).forEach(function (key) { var opts = props[key]; if (isPlainObject(opts)) {// title:{type:String,default:''} var value = opts.default; if (isFn(value)) { value = value(); } opts.type = parsePropType(key, opts.type); properties[key] = { type: PROP_TYPES.indexOf(opts.type) !== -1 ? opts.type : null, value: value, observer: createObserver(key) }; } else {// content:String var type = parsePropType(key, opts); properties[key] = { type: PROP_TYPES.indexOf(type) !== -1 ? type : null, observer: createObserver(key) }; } }); } return properties; } function wrapper$1(event) { // TODO 又得兼容 mpvue 的 mp 对象 try { event.mp = JSON.parse(JSON.stringify(event)); } catch (e) {} event.stopPropagation = noop; event.preventDefault = noop; event.target = event.target || {}; if (!hasOwn(event, 'detail')) { event.detail = {}; } if (hasOwn(event, 'markerId')) { event.detail = typeof event.detail === 'object' ? event.detail : {}; event.detail.markerId = event.markerId; } if (isPlainObject(event.detail)) { event.target = Object.assign({}, event.target, event.detail); } return event; } function getExtraValue(vm, dataPathsArray) { var context = vm; dataPathsArray.forEach(function (dataPathArray) { var dataPath = dataPathArray[0]; var value = dataPathArray[2]; if (dataPath || typeof value !== 'undefined') {// ['','',index,'disable'] var propPath = dataPathArray[1]; var valuePath = dataPathArray[3]; var vFor; if (Number.isInteger(dataPath)) { vFor = dataPath; } else if (!dataPath) { vFor = context; } else if (typeof dataPath === 'string' && dataPath) { if (dataPath.indexOf('#s#') === 0) { vFor = dataPath.substr(3); } else { vFor = vm.__get_value(dataPath, context); } } if (Number.isInteger(vFor)) { context = value; } else if (!propPath) { context = vFor[value]; } else { if (Array.isArray(vFor)) { context = vFor.find(function (vForItem) { return vm.__get_value(propPath, vForItem) === value; }); } else if (isPlainObject(vFor)) { context = Object.keys(vFor).find(function (vForKey) { return vm.__get_value(propPath, vFor[vForKey]) === value; }); } else { console.error('v-for 暂不支持循环数据:', vFor); } } if (valuePath) { context = vm.__get_value(valuePath, context); } } }); return context; } function processEventExtra(vm, extra, event) { var extraObj = {}; if (Array.isArray(extra) && extra.length) { /** *[ * ['data.items', 'data.id', item.data.id], * ['metas', 'id', meta.id] *], *[ * ['data.items', 'data.id', item.data.id], * ['metas', 'id', meta.id] *], *'test' */ extra.forEach(function (dataPath, index) { if (typeof dataPath === 'string') { if (!dataPath) {// model,prop.sync extraObj['$' + index] = vm; } else { if (dataPath === '$event') {// $event extraObj['$' + index] = event; } else if (dataPath === 'arguments') { if (event.detail && event.detail.__args__) { extraObj['$' + index] = event.detail.__args__; } else { extraObj['$' + index] = [event]; } } else if (dataPath.indexOf('$event.') === 0) {// $event.target.value extraObj['$' + index] = vm.__get_value(dataPath.replace('$event.', ''), event); } else { extraObj['$' + index] = vm.__get_value(dataPath); } } } else { extraObj['$' + index] = getExtraValue(vm, dataPath); } }); } return extraObj; } function getObjByArray(arr) { var obj = {}; for (var i = 1; i < arr.length; i++) { var element = arr[i]; obj[element[0]] = element[1]; } return obj; } function processEventArgs(vm, event) {var args = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];var extra = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];var isCustom = arguments.length > 4 ? arguments[4] : undefined;var methodName = arguments.length > 5 ? arguments[5] : undefined; var isCustomMPEvent = false; // wxcomponent 组件,传递原始 event 对象 if (isCustom) {// 自定义事件 isCustomMPEvent = event.currentTarget && event.currentTarget.dataset && event.currentTarget.dataset.comType === 'wx'; if (!args.length) {// 无参数,直接传入 event 或 detail 数组 if (isCustomMPEvent) { return [event]; } return event.detail.__args__ || event.detail; } } var extraObj = processEventExtra(vm, extra, event); var ret = []; args.forEach(function (arg) { if (arg === '$event') { if (methodName === '__set_model' && !isCustom) {// input v-model value ret.push(event.target.value); } else { if (isCustom && !isCustomMPEvent) { ret.push(event.detail.__args__[0]); } else {// wxcomponent 组件或内置组件 ret.push(event); } } } else { if (Array.isArray(arg) && arg[0] === 'o') { ret.push(getObjByArray(arg)); } else if (typeof arg === 'string' && hasOwn(extraObj, arg)) { ret.push(extraObj[arg]); } else { ret.push(arg); } } }); return ret; } var ONCE = '~'; var CUSTOM = '^'; function isMatchEventType(eventType, optType) { return eventType === optType || optType === 'regionchange' && ( eventType === 'begin' || eventType === 'end'); } function getContextVm(vm) { var $parent = vm.$parent; // 父组件是 scoped slots 或者其他自定义组件时继续查找 while ($parent && $parent.$parent && ($parent.$options.generic || $parent.$parent.$options.generic || $parent.$scope._$vuePid)) { $parent = $parent.$parent; } return $parent && $parent.$parent; } function handleEvent(event) {var _this = this; event = wrapper$1(event); // [['tap',[['handle',[1,2,a]],['handle1',[1,2,a]]]]] var dataset = (event.currentTarget || event.target).dataset; if (!dataset) { return console.warn('事件信息不存在'); } var eventOpts = dataset.eventOpts || dataset['event-opts']; // 支付宝 web-view 组件 dataset 非驼峰 if (!eventOpts) { return console.warn('事件信息不存在'); } // [['handle',[1,2,a]],['handle1',[1,2,a]]] var eventType = event.type; var ret = []; eventOpts.forEach(function (eventOpt) { var type = eventOpt[0]; var eventsArray = eventOpt[1]; var isCustom = type.charAt(0) === CUSTOM; type = isCustom ? type.slice(1) : type; var isOnce = type.charAt(0) === ONCE; type = isOnce ? type.slice(1) : type; if (eventsArray && isMatchEventType(eventType, type)) { eventsArray.forEach(function (eventArray) { var methodName = eventArray[0]; if (methodName) { var handlerCtx = _this.$vm; if (handlerCtx.$options.generic) {// mp-weixin,mp-toutiao 抽象节点模拟 scoped slots handlerCtx = getContextVm(handlerCtx) || handlerCtx; } if (methodName === '$emit') { handlerCtx.$emit.apply(handlerCtx, processEventArgs( _this.$vm, event, eventArray[1], eventArray[2], isCustom, methodName)); return; } var handler = handlerCtx[methodName]; if (!isFn(handler)) { throw new Error(" _vm.".concat(methodName, " is not a function")); } if (isOnce) { if (handler.once) { return; } handler.once = true; } var params = processEventArgs( _this.$vm, event, eventArray[1], eventArray[2], isCustom, methodName); params = Array.isArray(params) ? params : []; // 参数尾部增加原始事件对象用于复杂表达式内获取额外数据 if (/=\s*\S+\.eventParams\s*\|\|\s*\S+\[['"]event-params['"]\]/.test(handler.toString())) { // eslint-disable-next-line no-sparse-arrays params = params.concat([,,,,,,,,,, event]); } ret.push(handler.apply(handlerCtx, params)); } }); } }); if ( eventType === 'input' && ret.length === 1 && typeof ret[0] !== 'undefined') { return ret[0]; } } var messages = {}; var locale; { locale = wx.getSystemInfoSync().language; } function initI18nMessages() { if (!isEnableLocale()) { return; } var localeKeys = Object.keys(__uniConfig.locales); if (localeKeys.length) { localeKeys.forEach(function (locale) { var curMessages = messages[locale]; var userMessages = __uniConfig.locales[locale]; if (curMessages) { Object.assign(curMessages, userMessages); } else { messages[locale] = userMessages; } }); } } initI18nMessages(); var i18n = (0, _uniI18n.initVueI18n)( locale, {}); var t = i18n.t; var i18nMixin = i18n.mixin = { beforeCreate: function beforeCreate() {var _this2 = this; var unwatch = i18n.i18n.watchLocale(function () { _this2.$forceUpdate(); }); this.$once('hook:beforeDestroy', function () { unwatch(); }); }, methods: { $$t: function $$t(key, values) { return t(key, values); } } }; var setLocale$1 = i18n.setLocale; var getLocale$1 = i18n.getLocale; function initAppLocale(Vue, appVm, locale) { var state = Vue.observable({ locale: locale || i18n.getLocale() }); var localeWatchers = []; appVm.$watchLocale = function (fn) { localeWatchers.push(fn); }; Object.defineProperty(appVm, '$locale', { get: function get() { return state.locale; }, set: function set(v) { state.locale = v; localeWatchers.forEach(function (watch) {return watch(v);}); } }); } function isEnableLocale() { return typeof __uniConfig !== 'undefined' && __uniConfig.locales && !!Object.keys(__uniConfig.locales).length; } // export function initI18n() { // const localeKeys = Object.keys(__uniConfig.locales || {}) // if (localeKeys.length) { // localeKeys.forEach((locale) => // i18n.add(locale, __uniConfig.locales[locale]) // ) // } // } var eventChannels = {}; var eventChannelStack = []; function getEventChannel(id) { if (id) { var eventChannel = eventChannels[id]; delete eventChannels[id]; return eventChannel; } return eventChannelStack.shift(); } var hooks = [ 'onShow', 'onHide', 'onError', 'onPageNotFound', 'onThemeChange', 'onUnhandledRejection']; function initEventChannel() { _vue.default.prototype.getOpenerEventChannel = function () { // 微信小程序使用自身getOpenerEventChannel { return this.$scope.getOpenerEventChannel(); } }; var callHook = _vue.default.prototype.__call_hook; _vue.default.prototype.__call_hook = function (hook, args) { if (hook === 'onLoad' && args && args.__id__) { this.__eventChannel__ = getEventChannel(args.__id__); delete args.__id__; } return callHook.call(this, hook, args); }; } function initScopedSlotsParams() { var center = {}; var parents = {}; _vue.default.prototype.$hasScopedSlotsParams = function (vueId) { var has = center[vueId]; if (!has) { parents[vueId] = this; this.$on('hook:destroyed', function () { delete parents[vueId]; }); } return has; }; _vue.default.prototype.$getScopedSlotsParams = function (vueId, name, key) { var data = center[vueId]; if (data) { var object = data[name] || {}; return key ? object[key] : object; } else { parents[vueId] = this; this.$on('hook:destroyed', function () { delete parents[vueId]; }); } }; _vue.default.prototype.$setScopedSlotsParams = function (name, value) { var vueIds = this.$options.propsData.vueId; if (vueIds) { var vueId = vueIds.split(',')[0]; var object = center[vueId] = center[vueId] || {}; object[name] = value; if (parents[vueId]) { parents[vueId].$forceUpdate(); } } }; _vue.default.mixin({ destroyed: function destroyed() { var propsData = this.$options.propsData; var vueId = propsData && propsData.vueId; if (vueId) { delete center[vueId]; delete parents[vueId]; } } }); } function parseBaseApp(vm, _ref3) {var mocks = _ref3.mocks,initRefs = _ref3.initRefs; initEventChannel(); { initScopedSlotsParams(); } if (vm.$options.store) { _vue.default.prototype.$store = vm.$options.store; } uniIdMixin(_vue.default); _vue.default.prototype.mpHost = "mp-weixin"; _vue.default.mixin({ beforeCreate: function beforeCreate() { if (!this.$options.mpType) { return; } this.mpType = this.$options.mpType; this.$mp = _defineProperty({ data: {} }, this.mpType, this.$options.mpInstance); this.$scope = this.$options.mpInstance; delete this.$options.mpType; delete this.$options.mpInstance; if (this.mpType === 'page' && typeof getApp === 'function') {// hack vue-i18n var app = getApp(); if (app.$vm && app.$vm.$i18n) { this._i18n = app.$vm.$i18n; } } if (this.mpType !== 'app') { initRefs(this); initMocks(this, mocks); } } }); var appOptions = { onLaunch: function onLaunch(args) { if (this.$vm) {// 已经初始化过了,主要是为了百度,百度 onShow 在 onLaunch 之前 return; } { if (wx.canIUse && !wx.canIUse('nextTick')) {// 事实 上2.2.3 即可,简单使用 2.3.0 的 nextTick 判断 console.error('当前微信基础库版本过低,请将 微信开发者工具-详情-项目设置-调试基础库版本 更换为`2.3.0`以上'); } } this.$vm = vm; this.$vm.$mp = { app: this }; this.$vm.$scope = this; // vm 上也挂载 globalData this.$vm.globalData = this.globalData; this.$vm._isMounted = true; this.$vm.__call_hook('mounted', args); this.$vm.__call_hook('onLaunch', args); } }; // 兼容旧版本 globalData appOptions.globalData = vm.$options.globalData || {}; // 将 methods 中的方法挂在 getApp() 中 var methods = vm.$options.methods; if (methods) { Object.keys(methods).forEach(function (name) { appOptions[name] = methods[name]; }); } initAppLocale(_vue.default, vm, wx.getSystemInfoSync().language || 'zh-Hans'); initHooks(appOptions, hooks); return appOptions; } var mocks = ['__route__', '__wxExparserNodeId__', '__wxWebviewId__']; function findVmByVueId(vm, vuePid) { var $children = vm.$children; // 优先查找直属(反向查找:https://github.com/dcloudio/uni-app/issues/1200) for (var i = $children.length - 1; i >= 0; i--) { var childVm = $children[i]; if (childVm.$scope._$vueId === vuePid) { return childVm; } } // 反向递归查找 var parentVm; for (var _i = $children.length - 1; _i >= 0; _i--) { parentVm = findVmByVueId($children[_i], vuePid); if (parentVm) { return parentVm; } } } function initBehavior(options) { return Behavior(options); } function isPage() { return !!this.route; } function initRelation(detail) { this.triggerEvent('__l', detail); } function selectAllComponents(mpInstance, selector, $refs) { var components = mpInstance.selectAllComponents(selector); components.forEach(function (component) { var ref = component.dataset.ref; $refs[ref] = component.$vm || component; { if (component.dataset.vueGeneric === 'scoped') { component.selectAllComponents('.scoped-ref').forEach(function (scopedComponent) { selectAllComponents(scopedComponent, selector, $refs); }); } } }); } function initRefs(vm) { var mpInstance = vm.$scope; Object.defineProperty(vm, '$refs', { get: function get() { var $refs = {}; selectAllComponents(mpInstance, '.vue-ref', $refs); // TODO 暂不考虑 for 中的 scoped var forComponents = mpInstance.selectAllComponents('.vue-ref-in-for'); forComponents.forEach(function (component) { var ref = component.dataset.ref; if (!$refs[ref]) { $refs[ref] = []; } $refs[ref].push(component.$vm || component); }); return $refs; } }); } function handleLink(event) {var _ref4 = event.detail || event.value,vuePid = _ref4.vuePid,vueOptions = _ref4.vueOptions; // detail 是微信,value 是百度(dipatch) var parentVm; if (vuePid) { parentVm = findVmByVueId(this.$vm, vuePid); } if (!parentVm) { parentVm = this.$vm; } vueOptions.parent = parentVm; } function parseApp(vm) { return parseBaseApp(vm, { mocks: mocks, initRefs: initRefs }); } function createApp(vm) { App(parseApp(vm)); return vm; } var encodeReserveRE = /[!'()*]/g; var encodeReserveReplacer = function encodeReserveReplacer(c) {return '%' + c.charCodeAt(0).toString(16);}; var commaRE = /%2C/g; // fixed encodeURIComponent which is more conformant to RFC3986: // - escapes [!'()*] // - preserve commas var encode = function encode(str) {return encodeURIComponent(str). replace(encodeReserveRE, encodeReserveReplacer). replace(commaRE, ',');}; function stringifyQuery(obj) {var encodeStr = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : encode; var res = obj ? Object.keys(obj).map(function (key) { var val = obj[key]; if (val === undefined) { return ''; } if (val === null) { return encodeStr(key); } if (Array.isArray(val)) { var result = []; val.forEach(function (val2) { if (val2 === undefined) { return; } if (val2 === null) { result.push(encodeStr(key)); } else { result.push(encodeStr(key) + '=' + encodeStr(val2)); } }); return result.join('&'); } return encodeStr(key) + '=' + encodeStr(val); }).filter(function (x) {return x.length > 0;}).join('&') : null; return res ? "?".concat(res) : ''; } function parseBaseComponent(vueComponentOptions) {var _ref5 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},isPage = _ref5.isPage,initRelation = _ref5.initRelation;var _initVueComponent = initVueComponent(_vue.default, vueComponentOptions),_initVueComponent2 = _slicedToArray(_initVueComponent, 2),VueComponent = _initVueComponent2[0],vueOptions = _initVueComponent2[1]; var options = _objectSpread({ multipleSlots: true, addGlobalClass: true }, vueOptions.options || {}); { // 微信 multipleSlots 部分情况有 bug,导致内容顺序错乱 如 u-list,提供覆盖选项 if (vueOptions['mp-weixin'] && vueOptions['mp-weixin'].options) { Object.assign(options, vueOptions['mp-weixin'].options); } } var componentOptions = { options: options, data: initData(vueOptions, _vue.default.prototype), behaviors: initBehaviors(vueOptions, initBehavior), properties: initProperties(vueOptions.props, false, vueOptions.__file), lifetimes: { attached: function attached() { var properties = this.properties; var options = { mpType: isPage.call(this) ? 'page' : 'component', mpInstance: this, propsData: properties }; initVueIds(properties.vueId, this); // 处理父子关系 initRelation.call(this, { vuePid: this._$vuePid, vueOptions: options }); // 初始化 vue 实例 this.$vm = new VueComponent(options); // 处理$slots,$scopedSlots(暂不支持动态变化$slots) initSlots(this.$vm, properties.vueSlots); // 触发首次 setData this.$vm.$mount(); }, ready: function ready() { // 当组件 props 默认值为 true,初始化时传入 false 会导致 created,ready 触发, 但 attached 不触发 // https://developers.weixin.qq.com/community/develop/doc/00066ae2844cc0f8eb883e2a557800 if (this.$vm) { this.$vm._isMounted = true; this.$vm.__call_hook('mounted'); this.$vm.__call_hook('onReady'); } }, detached: function detached() { this.$vm && this.$vm.$destroy(); } }, pageLifetimes: { show: function show(args) { this.$vm && this.$vm.__call_hook('onPageShow', args); }, hide: function hide() { this.$vm && this.$vm.__call_hook('onPageHide'); }, resize: function resize(size) { this.$vm && this.$vm.__call_hook('onPageResize', size); } }, methods: { __l: handleLink, __e: handleEvent } }; // externalClasses if (vueOptions.externalClasses) { componentOptions.externalClasses = vueOptions.externalClasses; } if (Array.isArray(vueOptions.wxsCallMethods)) { vueOptions.wxsCallMethods.forEach(function (callMethod) { componentOptions.methods[callMethod] = function (args) { return this.$vm[callMethod](args); }; }); } if (isPage) { return componentOptions; } return [componentOptions, VueComponent]; } function parseComponent(vueComponentOptions) { return parseBaseComponent(vueComponentOptions, { isPage: isPage, initRelation: initRelation }); } var hooks$1 = [ 'onShow', 'onHide', 'onUnload']; hooks$1.push.apply(hooks$1, PAGE_EVENT_HOOKS); function parseBasePage(vuePageOptions, _ref6) {var isPage = _ref6.isPage,initRelation = _ref6.initRelation; var pageOptions = parseComponent(vuePageOptions); initHooks(pageOptions.methods, hooks$1, vuePageOptions); pageOptions.methods.onLoad = function (query) { this.options = query; var copyQuery = Object.assign({}, query); delete copyQuery.__id__; this.$page = { fullPath: '/' + (this.route || this.is) + stringifyQuery(copyQuery) }; this.$vm.$mp.query = query; // 兼容 mpvue this.$vm.__call_hook('onLoad', query); }; return pageOptions; } function parsePage(vuePageOptions) { return parseBasePage(vuePageOptions, { isPage: isPage, initRelation: initRelation }); } function createPage(vuePageOptions) { { return Component(parsePage(vuePageOptions)); } } function createComponent(vueOptions) { { return Component(parseComponent(vueOptions)); } } function createSubpackageApp(vm) { var appOptions = parseApp(vm); var app = getApp({ allowDefault: true }); vm.$scope = app; var globalData = app.globalData; if (globalData) { Object.keys(appOptions.globalData).forEach(function (name) { if (!hasOwn(globalData, name)) { globalData[name] = appOptions.globalData[name]; } }); } Object.keys(appOptions).forEach(function (name) { if (!hasOwn(app, name)) { app[name] = appOptions[name]; } }); if (isFn(appOptions.onShow) && wx.onAppShow) { wx.onAppShow(function () {for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {args[_key5] = arguments[_key5];} vm.__call_hook('onShow', args); }); } if (isFn(appOptions.onHide) && wx.onAppHide) { wx.onAppHide(function () {for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {args[_key6] = arguments[_key6];} vm.__call_hook('onHide', args); }); } if (isFn(appOptions.onLaunch)) { var args = wx.getLaunchOptionsSync && wx.getLaunchOptionsSync(); vm.__call_hook('onLaunch', args); } return vm; } function createPlugin(vm) { var appOptions = parseApp(vm); if (isFn(appOptions.onShow) && wx.onAppShow) { wx.onAppShow(function () {for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {args[_key7] = arguments[_key7];} vm.__call_hook('onShow', args); }); } if (isFn(appOptions.onHide) && wx.onAppHide) { wx.onAppHide(function () {for (var _len8 = arguments.length, args = new Array(_len8), _key8 = 0; _key8 < _len8; _key8++) {args[_key8] = arguments[_key8];} vm.__call_hook('onHide', args); }); } if (isFn(appOptions.onLaunch)) { var args = wx.getLaunchOptionsSync && wx.getLaunchOptionsSync(); vm.__call_hook('onLaunch', args); } return vm; } todos.forEach(function (todoApi) { protocols[todoApi] = false; }); canIUses.forEach(function (canIUseApi) { var apiName = protocols[canIUseApi] && protocols[canIUseApi].name ? protocols[canIUseApi].name : canIUseApi; if (!wx.canIUse(apiName)) { protocols[canIUseApi] = false; } }); var uni = {}; if (typeof Proxy !== 'undefined' && "mp-weixin" !== 'app-plus') { uni = new Proxy({}, { get: function get(target, name) { if (hasOwn(target, name)) { return target[name]; } if (baseApi[name]) { return baseApi[name]; } if (api[name]) { return promisify(name, api[name]); } { if (extraApi[name]) { return promisify(name, extraApi[name]); } if (todoApis[name]) { return promisify(name, todoApis[name]); } } if (eventApi[name]) { return eventApi[name]; } if (!hasOwn(wx, name) && !hasOwn(protocols, name)) { return; } return promisify(name, wrapper(name, wx[name])); }, set: function set(target, name, value) { target[name] = value; return true; } }); } else { Object.keys(baseApi).forEach(function (name) { uni[name] = baseApi[name]; }); { Object.keys(todoApis).forEach(function (name) { uni[name] = promisify(name, todoApis[name]); }); Object.keys(extraApi).forEach(function (name) { uni[name] = promisify(name, todoApis[name]); }); } Object.keys(eventApi).forEach(function (name) { uni[name] = eventApi[name]; }); Object.keys(api).forEach(function (name) { uni[name] = promisify(name, api[name]); }); Object.keys(wx).forEach(function (name) { if (hasOwn(wx, name) || hasOwn(protocols, name)) { uni[name] = promisify(name, wrapper(name, wx[name])); } }); } wx.createApp = createApp; wx.createPage = createPage; wx.createComponent = createComponent; wx.createSubpackageApp = createSubpackageApp; wx.createPlugin = createPlugin; var uni$1 = uni;var _default = uni$1;exports.default = _default; /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../../webpack/buildin/global.js */ 2))) /***/ }), /***/ 11: /*!**********************************************************************************************************!*\ !*** ./node_modules/@dcloudio/vue-cli-plugin-uni/packages/vue-loader/lib/runtime/componentNormalizer.js ***! \**********************************************************************************************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return normalizeComponent; }); /* globals __VUE_SSR_CONTEXT__ */ // IMPORTANT: Do NOT use ES2015 features in this file (except for modules). // This module is a runtime utility for cleaner component module output and will // be included in the final webpack user bundle. function normalizeComponent ( scriptExports, render, staticRenderFns, functionalTemplate, injectStyles, scopeId, moduleIdentifier, /* server only */ shadowMode, /* vue-cli only */ components, // fixed by xxxxxx auto components renderjs // fixed by xxxxxx renderjs ) { // Vue.extend constructor export interop var options = typeof scriptExports === 'function' ? scriptExports.options : scriptExports // fixed by xxxxxx auto components if (components) { if (!options.components) { options.components = {} } var hasOwn = Object.prototype.hasOwnProperty for (var name in components) { if (hasOwn.call(components, name) && !hasOwn.call(options.components, name)) { options.components[name] = components[name] } } } // fixed by xxxxxx renderjs if (renderjs) { (renderjs.beforeCreate || (renderjs.beforeCreate = [])).unshift(function() { this[renderjs.__module] = this }); (options.mixins || (options.mixins = [])).push(renderjs) } // render functions if (render) { options.render = render options.staticRenderFns = staticRenderFns options._compiled = true } // functional template if (functionalTemplate) { options.functional = true } // scopedId if (scopeId) { options._scopeId = 'data-v-' + scopeId } var hook if (moduleIdentifier) { // server build hook = function (context) { // 2.3 injection context = context || // cached call (this.$vnode && this.$vnode.ssrContext) || // stateful (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional // 2.2 with runInNewContext: true if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { context = __VUE_SSR_CONTEXT__ } // inject component styles if (injectStyles) { injectStyles.call(this, context) } // register component module identifier for async chunk inferrence if (context && context._registeredComponents) { context._registeredComponents.add(moduleIdentifier) } } // used by ssr in case component is cached and beforeCreate // never gets called options._ssrRegister = hook } else if (injectStyles) { hook = shadowMode ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) } : injectStyles } if (hook) { if (options.functional) { // for template-only hot-reload because in that case the render fn doesn't // go through the normalizer options._injectStyles = hook // register for functioal component in vue file var originalRender = options.render options.render = function renderWithStyleInjection (h, context) { hook.call(context) return originalRender(h, context) } } else { // inject component registration as beforeCreate hook var existing = options.beforeCreate options.beforeCreate = existing ? [].concat(existing, hook) : [hook] } } return { exports: scriptExports, options: options } } /***/ }), /***/ 16: /*!**************************************************!*\ !*** E:/隔离办公文件/东信/DX-xcx/pages/img/recharge.png ***! \**************************************************/ /*! no static exports found */ /***/ (function(module, exports) { module.exports = "data:image/png;base64,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" /***/ }), /***/ 19: /*!***********************************************************************!*\ !*** E:/隔离办公文件/东信/DX-xcx/wxcomponents/vant/weapp/dist/toast/toast.js ***! \***********************************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true });exports.default = void 0;var _validator = __webpack_require__(/*! ../common/validator */ 20); var defaultOptions = { type: 'text', mask: false, message: '', show: true, zIndex: 1000, duration: 2000, position: 'middle', forbidClick: false, loadingType: 'circular', selector: '#van-toast' }; var queue = []; var currentOptions = Object.assign({}, defaultOptions); function parseOptions(message) { return (0, _validator.isObj)(message) ? message : { message: message }; } function getContext() { var pages = getCurrentPages(); return pages[pages.length - 1]; } function Toast(toastOptions) { var options = Object.assign(Object.assign({}, currentOptions), parseOptions(toastOptions)); var context = options.context || getContext(); var toast = context.selectComponent(options.selector); if (!toast) { console.warn('未找到 van-toast 节点,请确认 selector 及 context 是否正确'); return; } delete options.context; delete options.selector; toast.clear = function () { toast.setData({ show: false }); if (options.onClose) { options.onClose(); } }; queue.push(toast); toast.setData(options); clearTimeout(toast.timer); if (options.duration != null && options.duration > 0) { toast.timer = setTimeout(function () { toast.clear(); queue = queue.filter(function (item) {return item !== toast;}); }, options.duration); } return toast; } var createMethod = function createMethod(type) {return function (options) {return Toast(Object.assign({ type: type }, parseOptions(options)));};}; Toast.loading = createMethod('loading'); Toast.success = createMethod('success'); Toast.fail = createMethod('fail'); Toast.clear = function () { queue.forEach(function (toast) { toast.clear(); }); queue = []; }; Toast.setDefaultOptions = function (options) { Object.assign(currentOptions, options); }; Toast.resetDefaultOptions = function () { currentOptions = Object.assign({}, defaultOptions); };var _default = Toast;exports.default = _default; /***/ }), /***/ 2: /*!***********************************!*\ !*** (webpack)/buildin/global.js ***! \***********************************/ /*! no static exports found */ /***/ (function(module, exports) { var g; // This works in non-strict mode g = (function() { return this; })(); try { // This works if eval is allowed (see CSP) g = g || new Function("return this")(); } catch (e) { // This works if the window reference is available if (typeof window === "object") g = window; } // g can still be undefined, but nothing to do about it... // We return undefined, instead of nothing here, so it's // easier to handle this case. if(!global) { ...} module.exports = g; /***/ }), /***/ 20: /*!****************************************************************************!*\ !*** E:/隔离办公文件/东信/DX-xcx/wxcomponents/vant/weapp/dist/common/validator.js ***! \****************************************************************************/ /*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true });exports.isFunction = isFunction;exports.isPlainObject = isPlainObject;exports.isPromise = isPromise;exports.isDef = isDef;exports.isObj = isObj;exports.isNumber = isNumber;exports.isBoolean = isBoolean;exports.isImageUrl = isImageUrl;exports.isVideoUrl = isVideoUrl; // eslint-disable-next-line @typescript-eslint/ban-types function isFunction(val) { return typeof val === 'function'; } function isPlainObject(val) { return val !== null && typeof val === 'object' && !Array.isArray(val); } function isPromise(val) { return isPlainObject(val) && isFunction(val.then) && isFunction(val.catch); } function isDef(value) { return value !== undefined && value !== null; } function isObj(x) { var type = typeof x; return x !== null && (type === 'object' || type === 'function'); } function isNumber(value) { return /^\d+(\.\d+)?$/.test(value); } function isBoolean(value) { return typeof value === 'boolean'; } var IMAGE_REGEXP = /\.(jpeg|jpg|gif|png|svg|webp|jfif|bmp|dpg)/i; var VIDEO_REGEXP = /\.(mp4|mpg|mpeg|dat|asf|avi|rm|rmvb|mov|wmv|flv|mkv)/i; function isImageUrl(url) { return IMAGE_REGEXP.test(url); } function isVideoUrl(url) { return VIDEO_REGEXP.test(url); } /***/ }), /***/ 27: /*!**********************************************!*\ !*** E:/隔离办公文件/东信/DX-xcx/pages/img/logo.png ***! \**********************************************/ /*! no static exports found */ /***/ (function(module, exports) { module.exports = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAIQAAACECAYAAABRRIOnAAAACXBIWXMAAAsTAAALEwEAmpwYAAAFHGlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDUgNzkuMTYzNDk5LCAyMDE4LzA4LzEzLTE2OjQwOjIyICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ0MgMjAxOSAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDIxLTA5LTMwVDEwOjQyOjA0KzA4OjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAyMS0wOS0zMFQxMDo0NDoyMCswODowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAyMS0wOS0zMFQxMDo0NDoyMCswODowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDoxN2I3ZDBiZS0xMDc4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" /***/ }), /***/ 3: /*!******************************************************************************************!*\ !*** ./node_modules/@dcloudio/vue-cli-plugin-uni/packages/mp-vue/dist/mp.runtime.esm.js ***! \******************************************************************************************/ /*! exports provided: default */ /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; __webpack_require__.r(__webpack_exports__); /* WEBPACK VAR INJECTION */(function(global) {/*! * Vue.js v2.6.11 * (c) 2014-2022 Evan You * Released under the MIT License. */ /* */ var emptyObject = Object.freeze({}); // These helpers produce better VM code in JS engines due to their // explicitness and function inlining. function isUndef (v) { return v === undefined || v === null } function isDef (v) { return v !== undefined && v !== null } function isTrue (v) { return v === true } function isFalse (v) { return v === false } /** * Check if value is primitive. */ function isPrimitive (value) { return ( typeof value === 'string' || typeof value === 'number' || // $flow-disable-line typeof value === 'symbol' || typeof value === 'boolean' ) } /** * Quick object check - this is primarily used to tell * Objects from primitive values when we know the value * is a JSON-compliant type. */ function isObject (obj) { return obj !== null && typeof obj === 'object' } /** * Get the raw type string of a value, e.g., [object Object]. */ var _toString = Object.prototype.toString; function toRawType (value) { return _toString.call(value).slice(8, -1) } /** * Strict object type check. Only returns true * for plain JavaScript objects. */ function isPlainObject (obj) { return _toString.call(obj) === '[object Object]' } function isRegExp (v) { return _toString.call(v) === '[object RegExp]' } /** * Check if val is a valid array index. */ function isValidArrayIndex (val) { var n = parseFloat(String(val)); return n >= 0 && Math.floor(n) === n && isFinite(val) } function isPromise (val) { return ( isDef(val) && typeof val.then === 'function' && typeof val.catch === 'function' ) } /** * Convert a value to a string that is actually rendered. */ function toString (val) { return val == null ? '' : Array.isArray(val) || (isPlainObject(val) && val.toString === _toString) ? JSON.stringify(val, null, 2) : String(val) } /** * Convert an input value to a number for persistence. * If the conversion fails, return original string. */ function toNumber (val) { var n = parseFloat(val); return isNaN(n) ? val : n } /** * Make a map and return a function for checking if a key * is in that map. */ function makeMap ( str, expectsLowerCase ) { var map = Object.create(null); var list = str.split(','); for (var i = 0; i < list.length; i++) { map[list[i]] = true; } return expectsLowerCase ? function (val) { return map[val.toLowerCase()]; } : function (val) { return map[val]; } } /** * Check if a tag is a built-in tag. */ var isBuiltInTag = makeMap('slot,component', true); /** * Check if an attribute is a reserved attribute. */ var isReservedAttribute = makeMap('key,ref,slot,slot-scope,is'); /** * Remove an item from an array. */ function remove (arr, item) { if (arr.length) { var index = arr.indexOf(item); if (index > -1) { return arr.splice(index, 1) } } } /** * Check whether an object has the property. */ var hasOwnProperty = Object.prototype.hasOwnProperty; function hasOwn (obj, key) { return hasOwnProperty.call(obj, key) } /** * Create a cached version of a pure function. */ function cached (fn) { var cache = Object.create(null); return (function cachedFn (str) { var hit = cache[str]; return hit || (cache[str] = fn(str)) }) } /** * Camelize a hyphen-delimited string. */ var camelizeRE = /-(\w)/g; var camelize = cached(function (str) { return str.replace(camelizeRE, function (_, c) { return c ? c.toUpperCase() : ''; }) }); /** * Capitalize a string. */ var capitalize = cached(function (str) { return str.charAt(0).toUpperCase() + str.slice(1) }); /** * Hyphenate a camelCase string. */ var hyphenateRE = /\B([A-Z])/g; var hyphenate = cached(function (str) { return str.replace(hyphenateRE, '-$1').toLowerCase() }); /** * Simple bind polyfill for environments that do not support it, * e.g., PhantomJS 1.x. Technically, we don't need this anymore * since native bind is now performant enough in most browsers. * But removing it would mean breaking code that was able to run in * PhantomJS 1.x, so this must be kept for backward compatibility. */ /* istanbul ignore next */ function polyfillBind (fn, ctx) { function boundFn (a) { var l = arguments.length; return l ? l > 1 ? fn.apply(ctx, arguments) : fn.call(ctx, a) : fn.call(ctx) } boundFn._length = fn.length; return boundFn } function nativeBind (fn, ctx) { return fn.bind(ctx) } var bind = Function.prototype.bind ? nativeBind : polyfillBind; /** * Convert an Array-like object to a real Array. */ function toArray (list, start) { start = start || 0; var i = list.length - start; var ret = new Array(i); while (i--) { ret[i] = list[i + start]; } return ret } /** * Mix properties into target object. */ function extend (to, _from) { for (var key in _from) { to[key] = _from[key]; } return to } /** * Merge an Array of Objects into a single Object. */ function toObject (arr) { var res = {}; for (var i = 0; i < arr.length; i++) { if (arr[i]) { extend(res, arr[i]); } } return res } /* eslint-disable no-unused-vars */ /** * Perform no operation. * Stubbing args to make Flow happy without leaving useless transpiled code * with ...rest (https://flow.org/blog/2017/05/07/Strict-Function-Call-Arity/). */ function noop (a, b, c) {} /** * Always return false. */ var no = function (a, b, c) { return false; }; /* eslint-enable no-unused-vars */ /** * Return the same value. */ var identity = function (_) { return _; }; /** * Check if two values are loosely equal - that is, * if they are plain objects, do they have the same shape? */ function looseEqual (a, b) { if (a === b) { return true } var isObjectA = isObject(a); var isObjectB = isObject(b); if (isObjectA && isObjectB) { try { var isArrayA = Array.isArray(a); var isArrayB = Array.isArray(b); if (isArrayA && isArrayB) { return a.length === b.length && a.every(function (e, i) { return looseEqual(e, b[i]) }) } else if (a instanceof Date && b instanceof Date) { return a.getTime() === b.getTime() } else if (!isArrayA && !isArrayB) { var keysA = Object.keys(a); var keysB = Object.keys(b); return keysA.length === keysB.length && keysA.every(function (key) { return looseEqual(a[key], b[key]) }) } else { /* istanbul ignore next */ return false } } catch (e) { /* istanbul ignore next */ return false } } else if (!isObjectA && !isObjectB) { return String(a) === String(b) } else { return false } } /** * Return the first index at which a loosely equal value can be * found in the array (if value is a plain object, the array must * contain an object of the same shape), or -1 if it is not present. */ function looseIndexOf (arr, val) { for (var i = 0; i < arr.length; i++) { if (looseEqual(arr[i], val)) { return i } } return -1 } /** * Ensure a function is called only once. */ function once (fn) { var called = false; return function () { if (!called) { called = true; fn.apply(this, arguments); } } } var ASSET_TYPES = [ 'component', 'directive', 'filter' ]; var LIFECYCLE_HOOKS = [ 'beforeCreate', 'created', 'beforeMount', 'mounted', 'beforeUpdate', 'updated', 'beforeDestroy', 'destroyed', 'activated', 'deactivated', 'errorCaptured', 'serverPrefetch' ]; /* */ var config = ({ /** * Option merge strategies (used in core/util/options) */ // $flow-disable-line optionMergeStrategies: Object.create(null), /** * Whether to suppress warnings. */ silent: false, /** * Show production mode tip message on boot? */ productionTip: "development" !== 'production', /** * Whether to enable devtools */ devtools: "development" !== 'production', /** * Whether to record perf */ performance: false, /** * Error handler for watcher errors */ errorHandler: null, /** * Warn handler for watcher warns */ warnHandler: null, /** * Ignore certain custom elements */ ignoredElements: [], /** * Custom user key aliases for v-on */ // $flow-disable-line keyCodes: Object.create(null), /** * Check if a tag is reserved so that it cannot be registered as a * component. This is platform-dependent and may be overwritten. */ isReservedTag: no, /** * Check if an attribute is reserved so that it cannot be used as a component * prop. This is platform-dependent and may be overwritten. */ isReservedAttr: no, /** * Check if a tag is an unknown element. * Platform-dependent. */ isUnknownElement: no, /** * Get the namespace of an element */ getTagNamespace: noop, /** * Parse the real tag name for the specific platform. */ parsePlatformTagName: identity, /** * Check if an attribute must be bound using property, e.g. value * Platform-dependent. */ mustUseProp: no, /** * Perform updates asynchronously. Intended to be used by Vue Test Utils * This will significantly reduce performance if set to false. */ async: true, /** * Exposed for legacy reasons */ _lifecycleHooks: LIFECYCLE_HOOKS }); /* */ /** * unicode letters used for parsing html tags, component names and property paths. * using https://www.w3.org/TR/html53/semantics-scripting.html#potentialcustomelementname * skipping \u10000-\uEFFFF due to it freezing up PhantomJS */ var unicodeRegExp = /a-zA-Z\u00B7\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u037D\u037F-\u1FFF\u200C-\u200D\u203F-\u2040\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD/; /** * Check if a string starts with $ or _ */ function isReserved (str) { var c = (str + '').charCodeAt(0); return c === 0x24 || c === 0x5F } /** * Define a property. */ function def (obj, key, val, enumerable) { Object.defineProperty(obj, key, { value: val, enumerable: !!enumerable, writable: true, configurable: true }); } /** * Parse simple path. */ var bailRE = new RegExp(("[^" + (unicodeRegExp.source) + ".$_\\d]")); function parsePath (path) { if (bailRE.test(path)) { return } var segments = path.split('.'); return function (obj) { for (var i = 0; i < segments.length; i++) { if (!obj) { return } obj = obj[segments[i]]; } return obj } } /* */ // can we use __proto__? var hasProto = '__proto__' in {}; // Browser environment sniffing var inBrowser = typeof window !== 'undefined'; var inWeex = typeof WXEnvironment !== 'undefined' && !!WXEnvironment.platform; var weexPlatform = inWeex && WXEnvironment.platform.toLowerCase(); var UA = inBrowser && window.navigator.userAgent.toLowerCase(); var isIE = UA && /msie|trident/.test(UA); var isIE9 = UA && UA.indexOf('msie 9.0') > 0; var isEdge = UA && UA.indexOf('edge/') > 0; var isAndroid = (UA && UA.indexOf('android') > 0) || (weexPlatform === 'android'); var isIOS = (UA && /iphone|ipad|ipod|ios/.test(UA)) || (weexPlatform === 'ios'); var isChrome = UA && /chrome\/\d+/.test(UA) && !isEdge; var isPhantomJS = UA && /phantomjs/.test(UA); var isFF = UA && UA.match(/firefox\/(\d+)/); // Firefox has a "watch" function on Object.prototype... var nativeWatch = ({}).watch; if (inBrowser) { try { var opts = {}; Object.defineProperty(opts, 'passive', ({ get: function get () { } })); // https://github.com/facebook/flow/issues/285 window.addEventListener('test-passive', null, opts); } catch (e) {} } // this needs to be lazy-evaled because vue may be required before // vue-server-renderer can set VUE_ENV var _isServer; var isServerRendering = function () { if (_isServer === undefined) { /* istanbul ignore if */ if (!inBrowser && !inWeex && typeof global !== 'undefined') { // detect presence of vue-server-renderer and avoid // Webpack shimming the process _isServer = global['process'] && global['process'].env.VUE_ENV === 'server'; } else { _isServer = false; } } return _isServer }; // detect devtools var devtools = inBrowser && window.__VUE_DEVTOOLS_GLOBAL_HOOK__; /* istanbul ignore next */ function isNative (Ctor) { return typeof Ctor === 'function' && /native code/.test(Ctor.toString()) } var hasSymbol = typeof Symbol !== 'undefined' && isNative(Symbol) && typeof Reflect !== 'undefined' && isNative(Reflect.ownKeys); var _Set; /* istanbul ignore if */ // $flow-disable-line if (typeof Set !== 'undefined' && isNative(Set)) { // use native Set when available. _Set = Set; } else { // a non-standard Set polyfill that only works with primitive keys. _Set = /*@__PURE__*/(function () { function Set () { this.set = Object.create(null); } Set.prototype.has = function has (key) { return this.set[key] === true }; Set.prototype.add = function add (key) { this.set[key] = true; }; Set.prototype.clear = function clear () { this.set = Object.create(null); }; return Set; }()); } /* */ var warn = noop; var tip = noop; var generateComponentTrace = (noop); // work around flow check var formatComponentName = (noop); if (true) { var hasConsole = typeof console !== 'undefined'; var classifyRE = /(?:^|[-_])(\w)/g; var classify = function (str) { return str .replace(classifyRE, function (c) { return c.toUpperCase(); }) .replace(/[-_]/g, ''); }; warn = function (msg, vm) { var trace = vm ? generateComponentTrace(vm) : ''; if (config.warnHandler) { config.warnHandler.call(null, msg, vm, trace); } else if (hasConsole && (!config.silent)) { console.error(("[Vue warn]: " + msg + trace)); } }; tip = function (msg, vm) { if (hasConsole && (!config.silent)) { console.warn("[Vue tip]: " + msg + ( vm ? generateComponentTrace(vm) : '' )); } }; formatComponentName = function (vm, includeFile) { if (vm.$root === vm) { if (vm.$options && vm.$options.__file) { // fixed by xxxxxx return ('') + vm.$options.__file } return '' } var options = typeof vm === 'function' && vm.cid != null ? vm.options : vm._isVue ? vm.$options || vm.constructor.options : vm; var name = options.name || options._componentTag; var file = options.__file; if (!name && file) { var match = file.match(/([^/\\]+)\.vue$/); name = match && match[1]; } return ( (name ? ("<" + (classify(name)) + ">") : "") + (file && includeFile !== false ? (" at " + file) : '') ) }; var repeat = function (str, n) { var res = ''; while (n) { if (n % 2 === 1) { res += str; } if (n > 1) { str += str; } n >>= 1; } return res }; generateComponentTrace = function (vm) { if (vm._isVue && vm.$parent) { var tree = []; var currentRecursiveSequence = 0; while (vm && vm.$options.name !== 'PageBody') { if (tree.length > 0) { var last = tree[tree.length - 1]; if (last.constructor === vm.constructor) { currentRecursiveSequence++; vm = vm.$parent; continue } else if (currentRecursiveSequence > 0) { tree[tree.length - 1] = [last, currentRecursiveSequence]; currentRecursiveSequence = 0; } } !vm.$options.isReserved && tree.push(vm); vm = vm.$parent; } return '\n\nfound in\n\n' + tree .map(function (vm, i) { return ("" + (i === 0 ? '---> ' : repeat(' ', 5 + i * 2)) + (Array.isArray(vm) ? ((formatComponentName(vm[0])) + "... (" + (vm[1]) + " recursive calls)") : formatComponentName(vm))); }) .join('\n') } else { return ("\n\n(found in " + (formatComponentName(vm)) + ")") } }; } /* */ var uid = 0; /** * A dep is an observable that can have multiple * directives subscribing to it. */ var Dep = function Dep () { this.id = uid++; this.subs = []; }; Dep.prototype.addSub = function addSub (sub) { this.subs.push(sub); }; Dep.prototype.removeSub = function removeSub (sub) { remove(this.subs, sub); }; Dep.prototype.depend = function depend () { if (Dep.SharedObject.target) { Dep.SharedObject.target.addDep(this); } }; Dep.prototype.notify = function notify () { // stabilize the subscriber list first var subs = this.subs.slice(); if ( true && !config.async) { // subs aren't sorted in scheduler if not running async // we need to sort them now to make sure they fire in correct // order subs.sort(function (a, b) { return a.id - b.id; }); } for (var i = 0, l = subs.length; i < l; i++) { subs[i].update(); } }; // The current target watcher being evaluated. // This is globally unique because only one watcher // can be evaluated at a time. // fixed by xxxxxx (nvue shared vuex) /* eslint-disable no-undef */ Dep.SharedObject = {}; Dep.SharedObject.target = null; Dep.SharedObject.targetStack = []; function pushTarget (target) { Dep.SharedObject.targetStack.push(target); Dep.SharedObject.target = target; Dep.target = target; } function popTarget () { Dep.SharedObject.targetStack.pop(); Dep.SharedObject.target = Dep.SharedObject.targetStack[Dep.SharedObject.targetStack.length - 1]; Dep.target = Dep.SharedObject.target; } /* */ var VNode = function VNode ( tag, data, children, text, elm, context, componentOptions, asyncFactory ) { this.tag = tag; this.data = data; this.children = children; this.text = text; this.elm = elm; this.ns = undefined; this.context = context; this.fnContext = undefined; this.fnOptions = undefined; this.fnScopeId = undefined; this.key = data && data.key; this.componentOptions = componentOptions; this.componentInstance = undefined; this.parent = undefined; this.raw = false; this.isStatic = false; this.isRootInsert = true; this.isComment = false; this.isCloned = false; this.isOnce = false; this.asyncFactory = asyncFactory; this.asyncMeta = undefined; this.isAsyncPlaceholder = false; }; var prototypeAccessors = { child: { configurable: true } }; // DEPRECATED: alias for componentInstance for backwards compat. /* istanbul ignore next */ prototypeAccessors.child.get = function () { return this.componentInstance }; Object.defineProperties( VNode.prototype, prototypeAccessors ); var createEmptyVNode = function (text) { if ( text === void 0 ) text = ''; var node = new VNode(); node.text = text; node.isComment = true; return node }; function createTextVNode (val) { return new VNode(undefined, undefined, undefined, String(val)) } // optimized shallow clone // used for static nodes and slot nodes because they may be reused across // multiple renders, cloning them avoids errors when DOM manipulations rely // on their elm reference. function cloneVNode (vnode) { var cloned = new VNode( vnode.tag, vnode.data, // #7975 // clone children array to avoid mutating original in case of cloning // a child. vnode.children && vnode.children.slice(), vnode.text, vnode.elm, vnode.context, vnode.componentOptions, vnode.asyncFactory ); cloned.ns = vnode.ns; cloned.isStatic = vnode.isStatic; cloned.key = vnode.key; cloned.isComment = vnode.isComment; cloned.fnContext = vnode.fnContext; cloned.fnOptions = vnode.fnOptions; cloned.fnScopeId = vnode.fnScopeId; cloned.asyncMeta = vnode.asyncMeta; cloned.isCloned = true; return cloned } /* * not type checking this file because flow doesn't play well with * dynamically accessing methods on Array prototype */ var arrayProto = Array.prototype; var arrayMethods = Object.create(arrayProto); var methodsToPatch = [ 'push', 'pop', 'shift', 'unshift', 'splice', 'sort', 'reverse' ]; /** * Intercept mutating methods and emit events */ methodsToPatch.forEach(function (method) { // cache original method var original = arrayProto[method]; def(arrayMethods, method, function mutator () { var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; var result = original.apply(this, args); var ob = this.__ob__; var inserted; switch (method) { case 'push': case 'unshift': inserted = args; break case 'splice': inserted = args.slice(2); break } if (inserted) { ob.observeArray(inserted); } // notify change ob.dep.notify(); return result }); }); /* */ var arrayKeys = Object.getOwnPropertyNames(arrayMethods); /** * In some cases we may want to disable observation inside a component's * update computation. */ var shouldObserve = true; function toggleObserving (value) { shouldObserve = value; } /** * Observer class that is attached to each observed * object. Once attached, the observer converts the target * object's property keys into getter/setters that * collect dependencies and dispatch updates. */ var Observer = function Observer (value) { this.value = value; this.dep = new Dep(); this.vmCount = 0; def(value, '__ob__', this); if (Array.isArray(value)) { if (hasProto) { {// fixed by xxxxxx 微信小程序使用 plugins 之后,数组方法被直接挂载到了数组对象上,需要执行 copyAugment 逻辑 if(value.push !== value.__proto__.push){ copyAugment(value, arrayMethods, arrayKeys); } else { protoAugment(value, arrayMethods); } } } else { copyAugment(value, arrayMethods, arrayKeys); } this.observeArray(value); } else { this.walk(value); } }; /** * Walk through all properties and convert them into * getter/setters. This method should only be called when * value type is Object. */ Observer.prototype.walk = function walk (obj) { var keys = Object.keys(obj); for (var i = 0; i < keys.length; i++) { defineReactive$$1(obj, keys[i]); } }; /** * Observe a list of Array items. */ Observer.prototype.observeArray = function observeArray (items) { for (var i = 0, l = items.length; i < l; i++) { observe(items[i]); } }; // helpers /** * Augment a target Object or Array by intercepting * the prototype chain using __proto__ */ function protoAugment (target, src) { /* eslint-disable no-proto */ target.__proto__ = src; /* eslint-enable no-proto */ } /** * Augment a target Object or Array by defining * hidden properties. */ /* istanbul ignore next */ function copyAugment (target, src, keys) { for (var i = 0, l = keys.length; i < l; i++) { var key = keys[i]; def(target, key, src[key]); } } /** * Attempt to create an observer instance for a value, * returns the new observer if successfully observed, * or the existing observer if the value already has one. */ function observe (value, asRootData) { if (!isObject(value) || value instanceof VNode) { return } var ob; if (hasOwn(value, '__ob__') && value.__ob__ instanceof Observer) { ob = value.__ob__; } else if ( shouldObserve && !isServerRendering() && (Array.isArray(value) || isPlainObject(value)) && Object.isExtensible(value) && !value._isVue ) { ob = new Observer(value); } if (asRootData && ob) { ob.vmCount++; } return ob } /** * Define a reactive property on an Object. */ function defineReactive$$1 ( obj, key, val, customSetter, shallow ) { var dep = new Dep(); var property = Object.getOwnPropertyDescriptor(obj, key); if (property && property.configurable === false) { return } // cater for pre-defined getter/setters var getter = property && property.get; var setter = property && property.set; if ((!getter || setter) && arguments.length === 2) { val = obj[key]; } var childOb = !shallow && observe(val); Object.defineProperty(obj, key, { enumerable: true, configurable: true, get: function reactiveGetter () { var value = getter ? getter.call(obj) : val; if (Dep.SharedObject.target) { // fixed by xxxxxx dep.depend(); if (childOb) { childOb.dep.depend(); if (Array.isArray(value)) { dependArray(value); } } } return value }, set: function reactiveSetter (newVal) { var value = getter ? getter.call(obj) : val; /* eslint-disable no-self-compare */ if (newVal === value || (newVal !== newVal && value !== value)) { return } /* eslint-enable no-self-compare */ if ( true && customSetter) { customSetter(); } // #7981: for accessor properties without setter if (getter && !setter) { return } if (setter) { setter.call(obj, newVal); } else { val = newVal; } childOb = !shallow && observe(newVal); dep.notify(); } }); } /** * Set a property on an object. Adds the new property and * triggers change notification if the property doesn't * already exist. */ function set (target, key, val) { if ( true && (isUndef(target) || isPrimitive(target)) ) { warn(("Cannot set reactive property on undefined, null, or primitive value: " + ((target)))); } if (Array.isArray(target) && isValidArrayIndex(key)) { target.length = Math.max(target.length, key); target.splice(key, 1, val); return val } if (key in target && !(key in Object.prototype)) { target[key] = val; return val } var ob = (target).__ob__; if (target._isVue || (ob && ob.vmCount)) { true && warn( 'Avoid adding reactive properties to a Vue instance or its root $data ' + 'at runtime - declare it upfront in the data option.' ); return val } if (!ob) { target[key] = val; return val } defineReactive$$1(ob.value, key, val); ob.dep.notify(); return val } /** * Delete a property and trigger change if necessary. */ function del (target, key) { if ( true && (isUndef(target) || isPrimitive(target)) ) { warn(("Cannot delete reactive property on undefined, null, or primitive value: " + ((target)))); } if (Array.isArray(target) && isValidArrayIndex(key)) { target.splice(key, 1); return } var ob = (target).__ob__; if (target._isVue || (ob && ob.vmCount)) { true && warn( 'Avoid deleting properties on a Vue instance or its root $data ' + '- just set it to null.' ); return } if (!hasOwn(target, key)) { return } delete target[key]; if (!ob) { return } ob.dep.notify(); } /** * Collect dependencies on array elements when the array is touched, since * we cannot intercept array element access like property getters. */ function dependArray (value) { for (var e = (void 0), i = 0, l = value.length; i < l; i++) { e = value[i]; e && e.__ob__ && e.__ob__.dep.depend(); if (Array.isArray(e)) { dependArray(e); } } } /* */ /** * Option overwriting strategies are functions that handle * how to merge a parent option value and a child option * value into the final value. */ var strats = config.optionMergeStrategies; /** * Options with restrictions */ if (true) { strats.el = strats.propsData = function (parent, child, vm, key) { if (!vm) { warn( "option \"" + key + "\" can only be used during instance " + 'creation with the `new` keyword.' ); } return defaultStrat(parent, child) }; } /** * Helper that recursively merges two data objects together. */ function mergeData (to, from) { if (!from) { return to } var key, toVal, fromVal; var keys = hasSymbol ? Reflect.ownKeys(from) : Object.keys(from); for (var i = 0; i < keys.length; i++) { key = keys[i]; // in case the object is already observed... if (key === '__ob__') { continue } toVal = to[key]; fromVal = from[key]; if (!hasOwn(to, key)) { set(to, key, fromVal); } else if ( toVal !== fromVal && isPlainObject(toVal) && isPlainObject(fromVal) ) { mergeData(toVal, fromVal); } } return to } /** * Data */ function mergeDataOrFn ( parentVal, childVal, vm ) { if (!vm) { // in a Vue.extend merge, both should be functions if (!childVal) { return parentVal } if (!parentVal) { return childVal } // when parentVal & childVal are both present, // we need to return a function that returns the // merged result of both functions... no need to // check if parentVal is a function here because // it has to be a function to pass previous merges. return function mergedDataFn () { return mergeData( typeof childVal === 'function' ? childVal.call(this, this) : childVal, typeof parentVal === 'function' ? parentVal.call(this, this) : parentVal ) } } else { return function mergedInstanceDataFn () { // instance merge var instanceData = typeof childVal === 'function' ? childVal.call(vm, vm) : childVal; var defaultData = typeof parentVal === 'function' ? parentVal.call(vm, vm) : parentVal; if (instanceData) { return mergeData(instanceData, defaultData) } else { return defaultData } } } } strats.data = function ( parentVal, childVal, vm ) { if (!vm) { if (childVal && typeof childVal !== 'function') { true && warn( 'The "data" option should be a function ' + 'that returns a per-instance value in component ' + 'definitions.', vm ); return parentVal } return mergeDataOrFn(parentVal, childVal) } return mergeDataOrFn(parentVal, childVal, vm) }; /** * Hooks and props are merged as arrays. */ function mergeHook ( parentVal, childVal ) { var res = childVal ? parentVal ? parentVal.concat(childVal) : Array.isArray(childVal) ? childVal : [childVal] : parentVal; return res ? dedupeHooks(res) : res } function dedupeHooks (hooks) { var res = []; for (var i = 0; i < hooks.length; i++) { if (res.indexOf(hooks[i]) === -1) { res.push(hooks[i]); } } return res } LIFECYCLE_HOOKS.forEach(function (hook) { strats[hook] = mergeHook; }); /** * Assets * * When a vm is present (instance creation), we need to do * a three-way merge between constructor options, instance * options and parent options. */ function mergeAssets ( parentVal, childVal, vm, key ) { var res = Object.create(parentVal || null); if (childVal) { true && assertObjectType(key, childVal, vm); return extend(res, childVal) } else { return res } } ASSET_TYPES.forEach(function (type) { strats[type + 's'] = mergeAssets; }); /** * Watchers. * * Watchers hashes should not overwrite one * another, so we merge them as arrays. */ strats.watch = function ( parentVal, childVal, vm, key ) { // work around Firefox's Object.prototype.watch... if (parentVal === nativeWatch) { parentVal = undefined; } if (childVal === nativeWatch) { childVal = undefined; } /* istanbul ignore if */ if (!childVal) { return Object.create(parentVal || null) } if (true) { assertObjectType(key, childVal, vm); } if (!parentVal) { return childVal } var ret = {}; extend(ret, parentVal); for (var key$1 in childVal) { var parent = ret[key$1]; var child = childVal[key$1]; if (parent && !Array.isArray(parent)) { parent = [parent]; } ret[key$1] = parent ? parent.concat(child) : Array.isArray(child) ? child : [child]; } return ret }; /** * Other object hashes. */ strats.props = strats.methods = strats.inject = strats.computed = function ( parentVal, childVal, vm, key ) { if (childVal && "development" !== 'production') { assertObjectType(key, childVal, vm); } if (!parentVal) { return childVal } var ret = Object.create(null); extend(ret, parentVal); if (childVal) { extend(ret, childVal); } return ret }; strats.provide = mergeDataOrFn; /** * Default strategy. */ var defaultStrat = function (parentVal, childVal) { return childVal === undefined ? parentVal : childVal }; /** * Validate component names */ function checkComponents (options) { for (var key in options.components) { validateComponentName(key); } } function validateComponentName (name) { if (!new RegExp(("^[a-zA-Z][\\-\\.0-9_" + (unicodeRegExp.source) + "]*$")).test(name)) { warn( 'Invalid component name: "' + name + '". Component names ' + 'should conform to valid custom element name in html5 specification.' ); } if (isBuiltInTag(name) || config.isReservedTag(name)) { warn( 'Do not use built-in or reserved HTML elements as component ' + 'id: ' + name ); } } /** * Ensure all props option syntax are normalized into the * Object-based format. */ function normalizeProps (options, vm) { var props = options.props; if (!props) { return } var res = {}; var i, val, name; if (Array.isArray(props)) { i = props.length; while (i--) { val = props[i]; if (typeof val === 'string') { name = camelize(val); res[name] = { type: null }; } else if (true) { warn('props must be strings when using array syntax.'); } } } else if (isPlainObject(props)) { for (var key in props) { val = props[key]; name = camelize(key); res[name] = isPlainObject(val) ? val : { type: val }; } } else if (true) { warn( "Invalid value for option \"props\": expected an Array or an Object, " + "but got " + (toRawType(props)) + ".", vm ); } options.props = res; } /** * Normalize all injections into Object-based format */ function normalizeInject (options, vm) { var inject = options.inject; if (!inject) { return } var normalized = options.inject = {}; if (Array.isArray(inject)) { for (var i = 0; i < inject.length; i++) { normalized[inject[i]] = { from: inject[i] }; } } else if (isPlainObject(inject)) { for (var key in inject) { var val = inject[key]; normalized[key] = isPlainObject(val) ? extend({ from: key }, val) : { from: val }; } } else if (true) { warn( "Invalid value for option \"inject\": expected an Array or an Object, " + "but got " + (toRawType(inject)) + ".", vm ); } } /** * Normalize raw function directives into object format. */ function normalizeDirectives (options) { var dirs = options.directives; if (dirs) { for (var key in dirs) { var def$$1 = dirs[key]; if (typeof def$$1 === 'function') { dirs[key] = { bind: def$$1, update: def$$1 }; } } } } function assertObjectType (name, value, vm) { if (!isPlainObject(value)) { warn( "Invalid value for option \"" + name + "\": expected an Object, " + "but got " + (toRawType(value)) + ".", vm ); } } /** * Merge two option objects into a new one. * Core utility used in both instantiation and inheritance. */ function mergeOptions ( parent, child, vm ) { if (true) { checkComponents(child); } if (typeof child === 'function') { child = child.options; } normalizeProps(child, vm); normalizeInject(child, vm); normalizeDirectives(child); // Apply extends and mixins on the child options, // but only if it is a raw options object that isn't // the result of another mergeOptions call. // Only merged options has the _base property. if (!child._base) { if (child.extends) { parent = mergeOptions(parent, child.extends, vm); } if (child.mixins) { for (var i = 0, l = child.mixins.length; i < l; i++) { parent = mergeOptions(parent, child.mixins[i], vm); } } } var options = {}; var key; for (key in parent) { mergeField(key); } for (key in child) { if (!hasOwn(parent, key)) { mergeField(key); } } function mergeField (key) { var strat = strats[key] || defaultStrat; options[key] = strat(parent[key], child[key], vm, key); } return options } /** * Resolve an asset. * This function is used because child instances need access * to assets defined in its ancestor chain. */ function resolveAsset ( options, type, id, warnMissing ) { /* istanbul ignore if */ if (typeof id !== 'string') { return } var assets = options[type]; // check local registration variations first if (hasOwn(assets, id)) { return assets[id] } var camelizedId = camelize(id); if (hasOwn(assets, camelizedId)) { return assets[camelizedId] } var PascalCaseId = capitalize(camelizedId); if (hasOwn(assets, PascalCaseId)) { return assets[PascalCaseId] } // fallback to prototype chain var res = assets[id] || assets[camelizedId] || assets[PascalCaseId]; if ( true && warnMissing && !res) { warn( 'Failed to resolve ' + type.slice(0, -1) + ': ' + id, options ); } return res } /* */ function validateProp ( key, propOptions, propsData, vm ) { var prop = propOptions[key]; var absent = !hasOwn(propsData, key); var value = propsData[key]; // boolean casting var booleanIndex = getTypeIndex(Boolean, prop.type); if (booleanIndex > -1) { if (absent && !hasOwn(prop, 'default')) { value = false; } else if (value === '' || value === hyphenate(key)) { // only cast empty string / same name to boolean if // boolean has higher priority var stringIndex = getTypeIndex(String, prop.type); if (stringIndex < 0 || booleanIndex < stringIndex) { value = true; } } } // check default value if (value === undefined) { value = getPropDefaultValue(vm, prop, key); // since the default value is a fresh copy, // make sure to observe it. var prevShouldObserve = shouldObserve; toggleObserving(true); observe(value); toggleObserving(prevShouldObserve); } if ( true ) { assertProp(prop, key, value, vm, absent); } return value } /** * Get the default value of a prop. */ function getPropDefaultValue (vm, prop, key) { // no default, return undefined if (!hasOwn(prop, 'default')) { return undefined } var def = prop.default; // warn against non-factory defaults for Object & Array if ( true && isObject(def)) { warn( 'Invalid default value for prop "' + key + '": ' + 'Props with type Object/Array must use a factory function ' + 'to return the default value.', vm ); } // the raw prop value was also undefined from previous render, // return previous default value to avoid unnecessary watcher trigger if (vm && vm.$options.propsData && vm.$options.propsData[key] === undefined && vm._props[key] !== undefined ) { return vm._props[key] } // call factory function for non-Function types // a value is Function if its prototype is function even across different execution context return typeof def === 'function' && getType(prop.type) !== 'Function' ? def.call(vm) : def } /** * Assert whether a prop is valid. */ function assertProp ( prop, name, value, vm, absent ) { if (prop.required && absent) { warn( 'Missing required prop: "' + name + '"', vm ); return } if (value == null && !prop.required) { return } var type = prop.type; var valid = !type || type === true; var expectedTypes = []; if (type) { if (!Array.isArray(type)) { type = [type]; } for (var i = 0; i < type.length && !valid; i++) { var assertedType = assertType(value, type[i]); expectedTypes.push(assertedType.expectedType || ''); valid = assertedType.valid; } } if (!valid) { warn( getInvalidTypeMessage(name, value, expectedTypes), vm ); return } var validator = prop.validator; if (validator) { if (!validator(value)) { warn( 'Invalid prop: custom validator check failed for prop "' + name + '".', vm ); } } } var simpleCheckRE = /^(String|Number|Boolean|Function|Symbol)$/; function assertType (value, type) { var valid; var expectedType = getType(type); if (simpleCheckRE.test(expectedType)) { var t = typeof value; valid = t === expectedType.toLowerCase(); // for primitive wrapper objects if (!valid && t === 'object') { valid = value instanceof type; } } else if (expectedType === 'Object') { valid = isPlainObject(value); } else if (expectedType === 'Array') { valid = Array.isArray(value); } else { valid = value instanceof type; } return { valid: valid, expectedType: expectedType } } /** * Use function string name to check built-in types, * because a simple equality check will fail when running * across different vms / iframes. */ function getType (fn) { var match = fn && fn.toString().match(/^\s*function (\w+)/); return match ? match[1] : '' } function isSameType (a, b) { return getType(a) === getType(b) } function getTypeIndex (type, expectedTypes) { if (!Array.isArray(expectedTypes)) { return isSameType(expectedTypes, type) ? 0 : -1 } for (var i = 0, len = expectedTypes.length; i < len; i++) { if (isSameType(expectedTypes[i], type)) { return i } } return -1 } function getInvalidTypeMessage (name, value, expectedTypes) { var message = "Invalid prop: type check failed for prop \"" + name + "\"." + " Expected " + (expectedTypes.map(capitalize).join(', ')); var expectedType = expectedTypes[0]; var receivedType = toRawType(value); var expectedValue = styleValue(value, expectedType); var receivedValue = styleValue(value, receivedType); // check if we need to specify expected value if (expectedTypes.length === 1 && isExplicable(expectedType) && !isBoolean(expectedType, receivedType)) { message += " with value " + expectedValue; } message += ", got " + receivedType + " "; // check if we need to specify received value if (isExplicable(receivedType)) { message += "with value " + receivedValue + "."; } return message } function styleValue (value, type) { if (type === 'String') { return ("\"" + value + "\"") } else if (type === 'Number') { return ("" + (Number(value))) } else { return ("" + value) } } function isExplicable (value) { var explicitTypes = ['string', 'number', 'boolean']; return explicitTypes.some(function (elem) { return value.toLowerCase() === elem; }) } function isBoolean () { var args = [], len = arguments.length; while ( len-- ) args[ len ] = arguments[ len ]; return args.some(function (elem) { return elem.toLowerCase() === 'boolean'; }) } /* */ function handleError (err, vm, info) { // Deactivate deps tracking while processing error handler to avoid possible infinite rendering. // See: https://github.com/vuejs/vuex/issues/1505 pushTarget(); try { if (vm) { var cur = vm; while ((cur = cur.$parent)) { var hooks = cur.$options.errorCaptured; if (hooks) { for (var i = 0; i < hooks.length; i++) { try { var capture = hooks[i].call(cur, err, vm, info) === false; if (capture) { return } } catch (e) { globalHandleError(e, cur, 'errorCaptured hook'); } } } } } globalHandleError(err, vm, info); } finally { popTarget(); } } function invokeWithErrorHandling ( handler, context, args, vm, info ) { var res; try { res = args ? handler.apply(context, args) : handler.call(context); if (res && !res._isVue && isPromise(res) && !res._handled) { res.catch(function (e) { return handleError(e, vm, info + " (Promise/async)"); }); // issue #9511 // avoid catch triggering multiple times when nested calls res._handled = true; } } catch (e) { handleError(e, vm, info); } return res } function globalHandleError (err, vm, info) { if (config.errorHandler) { try { return config.errorHandler.call(null, err, vm, info) } catch (e) { // if the user intentionally throws the original error in the handler, // do not log it twice if (e !== err) { logError(e, null, 'config.errorHandler'); } } } logError(err, vm, info); } function logError (err, vm, info) { if (true) { warn(("Error in " + info + ": \"" + (err.toString()) + "\""), vm); } /* istanbul ignore else */ if ((inBrowser || inWeex) && typeof console !== 'undefined') { console.error(err); } else { throw err } } /* */ var callbacks = []; var pending = false; function flushCallbacks () { pending = false; var copies = callbacks.slice(0); callbacks.length = 0; for (var i = 0; i < copies.length; i++) { copies[i](); } } // Here we have async deferring wrappers using microtasks. // In 2.5 we used (macro) tasks (in combination with microtasks). // However, it has subtle problems when state is changed right before repaint // (e.g. #6813, out-in transitions). // Also, using (macro) tasks in event handler would cause some weird behaviors // that cannot be circumvented (e.g. #7109, #7153, #7546, #7834, #8109). // So we now use microtasks everywhere, again. // A major drawback of this tradeoff is that there are some scenarios // where microtasks have too high a priority and fire in between supposedly // sequential events (e.g. #4521, #6690, which have workarounds) // or even between bubbling of the same event (#6566). var timerFunc; // The nextTick behavior leverages the microtask queue, which can be accessed // via either native Promise.then or MutationObserver. // MutationObserver has wider support, however it is seriously bugged in // UIWebView in iOS >= 9.3.3 when triggered in touch event handlers. It // completely stops working after triggering a few times... so, if native // Promise is available, we will use it: /* istanbul ignore next, $flow-disable-line */ if (typeof Promise !== 'undefined' && isNative(Promise)) { var p = Promise.resolve(); timerFunc = function () { p.then(flushCallbacks); // In problematic UIWebViews, Promise.then doesn't completely break, but // it can get stuck in a weird state where callbacks are pushed into the // microtask queue but the queue isn't being flushed, until the browser // needs to do some other work, e.g. handle a timer. Therefore we can // "force" the microtask queue to be flushed by adding an empty timer. if (isIOS) { setTimeout(noop); } }; } else if (!isIE && typeof MutationObserver !== 'undefined' && ( isNative(MutationObserver) || // PhantomJS and iOS 7.x MutationObserver.toString() === '[object MutationObserverConstructor]' )) { // Use MutationObserver where native Promise is not available, // e.g. PhantomJS, iOS7, Android 4.4 // (#6466 MutationObserver is unreliable in IE11) var counter = 1; var observer = new MutationObserver(flushCallbacks); var textNode = document.createTextNode(String(counter)); observer.observe(textNode, { characterData: true }); timerFunc = function () { counter = (counter + 1) % 2; textNode.data = String(counter); }; } else if (typeof setImmediate !== 'undefined' && isNative(setImmediate)) { // Fallback to setImmediate. // Technically it leverages the (macro) task queue, // but it is still a better choice than setTimeout. timerFunc = function () { setImmediate(flushCallbacks); }; } else { // Fallback to setTimeout. timerFunc = function () { setTimeout(flushCallbacks, 0); }; } function nextTick (cb, ctx) { var _resolve; callbacks.push(function () { if (cb) { try { cb.call(ctx); } catch (e) { handleError(e, ctx, 'nextTick'); } } else if (_resolve) { _resolve(ctx); } }); if (!pending) { pending = true; timerFunc(); } // $flow-disable-line if (!cb && typeof Promise !== 'undefined') { return new Promise(function (resolve) { _resolve = resolve; }) } } /* */ /* not type checking this file because flow doesn't play well with Proxy */ var initProxy; if (true) { var allowedGlobals = makeMap( 'Infinity,undefined,NaN,isFinite,isNaN,' + 'parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent,' + 'Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl,' + 'require' // for Webpack/Browserify ); var warnNonPresent = function (target, key) { warn( "Property or method \"" + key + "\" is not defined on the instance but " + 'referenced during render. Make sure that this property is reactive, ' + 'either in the data option, or for class-based components, by ' + 'initializing the property. ' + 'See: https://vuejs.org/v2/guide/reactivity.html#Declaring-Reactive-Properties.', target ); }; var warnReservedPrefix = function (target, key) { warn( "Property \"" + key + "\" must be accessed with \"$data." + key + "\" because " + 'properties starting with "$" or "_" are not proxied in the Vue instance to ' + 'prevent conflicts with Vue internals. ' + 'See: https://vuejs.org/v2/api/#data', target ); }; var hasProxy = typeof Proxy !== 'undefined' && isNative(Proxy); if (hasProxy) { var isBuiltInModifier = makeMap('stop,prevent,self,ctrl,shift,alt,meta,exact'); config.keyCodes = new Proxy(config.keyCodes, { set: function set (target, key, value) { if (isBuiltInModifier(key)) { warn(("Avoid overwriting built-in modifier in config.keyCodes: ." + key)); return false } else { target[key] = value; return true } } }); } var hasHandler = { has: function has (target, key) { var has = key in target; var isAllowed = allowedGlobals(key) || (typeof key === 'string' && key.charAt(0) === '_' && !(key in target.$data)); if (!has && !isAllowed) { if (key in target.$data) { warnReservedPrefix(target, key); } else { warnNonPresent(target, key); } } return has || !isAllowed } }; var getHandler = { get: function get (target, key) { if (typeof key === 'string' && !(key in target)) { if (key in target.$data) { warnReservedPrefix(target, key); } else { warnNonPresent(target, key); } } return target[key] } }; initProxy = function initProxy (vm) { if (hasProxy) { // determine which proxy handler to use var options = vm.$options; var handlers = options.render && options.render._withStripped ? getHandler : hasHandler; vm._renderProxy = new Proxy(vm, handlers); } else { vm._renderProxy = vm; } }; } /* */ var seenObjects = new _Set(); /** * Recursively traverse an object to evoke all converted * getters, so that every nested property inside the object * is collected as a "deep" dependency. */ function traverse (val) { _traverse(val, seenObjects); seenObjects.clear(); } function _traverse (val, seen) { var i, keys; var isA = Array.isArray(val); if ((!isA && !isObject(val)) || Object.isFrozen(val) || val instanceof VNode) { return } if (val.__ob__) { var depId = val.__ob__.dep.id; if (seen.has(depId)) { return } seen.add(depId); } if (isA) { i = val.length; while (i--) { _traverse(val[i], seen); } } else { keys = Object.keys(val); i = keys.length; while (i--) { _traverse(val[keys[i]], seen); } } } var mark; var measure; if (true) { var perf = inBrowser && window.performance; /* istanbul ignore if */ if ( perf && perf.mark && perf.measure && perf.clearMarks && perf.clearMeasures ) { mark = function (tag) { return perf.mark(tag); }; measure = function (name, startTag, endTag) { perf.measure(name, startTag, endTag); perf.clearMarks(startTag); perf.clearMarks(endTag); // perf.clearMeasures(name) }; } } /* */ var normalizeEvent = cached(function (name) { var passive = name.charAt(0) === '&'; name = passive ? name.slice(1) : name; var once$$1 = name.charAt(0) === '~'; // Prefixed last, checked first name = once$$1 ? name.slice(1) : name; var capture = name.charAt(0) === '!'; name = capture ? name.slice(1) : name; return { name: name, once: once$$1, capture: capture, passive: passive } }); function createFnInvoker (fns, vm) { function invoker () { var arguments$1 = arguments; var fns = invoker.fns; if (Array.isArray(fns)) { var cloned = fns.slice(); for (var i = 0; i < cloned.length; i++) { invokeWithErrorHandling(cloned[i], null, arguments$1, vm, "v-on handler"); } } else { // return handler return value for single handlers return invokeWithErrorHandling(fns, null, arguments, vm, "v-on handler") } } invoker.fns = fns; return invoker } function updateListeners ( on, oldOn, add, remove$$1, createOnceHandler, vm ) { var name, def$$1, cur, old, event; for (name in on) { def$$1 = cur = on[name]; old = oldOn[name]; event = normalizeEvent(name); if (isUndef(cur)) { true && warn( "Invalid handler for event \"" + (event.name) + "\": got " + String(cur), vm ); } else if (isUndef(old)) { if (isUndef(cur.fns)) { cur = on[name] = createFnInvoker(cur, vm); } if (isTrue(event.once)) { cur = on[name] = createOnceHandler(event.name, cur, event.capture); } add(event.name, cur, event.capture, event.passive, event.params); } else if (cur !== old) { old.fns = cur; on[name] = old; } } for (name in oldOn) { if (isUndef(on[name])) { event = normalizeEvent(name); remove$$1(event.name, oldOn[name], event.capture); } } } /* */ /* */ // fixed by xxxxxx (mp properties) function extractPropertiesFromVNodeData(data, Ctor, res, context) { var propOptions = Ctor.options.mpOptions && Ctor.options.mpOptions.properties; if (isUndef(propOptions)) { return res } var externalClasses = Ctor.options.mpOptions.externalClasses || []; var attrs = data.attrs; var props = data.props; if (isDef(attrs) || isDef(props)) { for (var key in propOptions) { var altKey = hyphenate(key); var result = checkProp(res, props, key, altKey, true) || checkProp(res, attrs, key, altKey, false); // externalClass if ( result && res[key] && externalClasses.indexOf(altKey) !== -1 && context[camelize(res[key])] ) { // 赋值 externalClass 真正的值(模板里 externalClass 的值可能是字符串) res[key] = context[camelize(res[key])]; } } } return res } function extractPropsFromVNodeData ( data, Ctor, tag, context// fixed by xxxxxx ) { // we are only extracting raw values here. // validation and default values are handled in the child // component itself. var propOptions = Ctor.options.props; if (isUndef(propOptions)) { // fixed by xxxxxx return extractPropertiesFromVNodeData(data, Ctor, {}, context) } var res = {}; var attrs = data.attrs; var props = data.props; if (isDef(attrs) || isDef(props)) { for (var key in propOptions) { var altKey = hyphenate(key); if (true) { var keyInLowerCase = key.toLowerCase(); if ( key !== keyInLowerCase && attrs && hasOwn(attrs, keyInLowerCase) ) { tip( "Prop \"" + keyInLowerCase + "\" is passed to component " + (formatComponentName(tag || Ctor)) + ", but the declared prop name is" + " \"" + key + "\". " + "Note that HTML attributes are case-insensitive and camelCased " + "props need to use their kebab-case equivalents when using in-DOM " + "templates. You should probably use \"" + altKey + "\" instead of \"" + key + "\"." ); } } checkProp(res, props, key, altKey, true) || checkProp(res, attrs, key, altKey, false); } } // fixed by xxxxxx return extractPropertiesFromVNodeData(data, Ctor, res, context) } function checkProp ( res, hash, key, altKey, preserve ) { if (isDef(hash)) { if (hasOwn(hash, key)) { res[key] = hash[key]; if (!preserve) { delete hash[key]; } return true } else if (hasOwn(hash, altKey)) { res[key] = hash[altKey]; if (!preserve) { delete hash[altKey]; } return true } } return false } /* */ // The template compiler attempts to minimize the need for normalization by // statically analyzing the template at compile time. // // For plain HTML markup, normalization can be completely skipped because the // generated render function is guaranteed to return Array. There are // two cases where extra normalization is needed: // 1. When the children contains components - because a functional component // may return an Array instead of a single root. In this case, just a simple // normalization is needed - if any child is an Array, we flatten the whole // thing with Array.prototype.concat. It is guaranteed to be only 1-level deep // because functional components already normalize their own children. function simpleNormalizeChildren (children) { for (var i = 0; i < children.length; i++) { if (Array.isArray(children[i])) { return Array.prototype.concat.apply([], children) } } return children } // 2. When the children contains constructs that always generated nested Arrays, // e.g.