| 
						 | 
						- 'use strict'
 - 
 - // utils is a library of generic helper functions non-specific to axios
 - 
 - var toString = Object.prototype.toString
 - 
 - /**
 -  * Determine if a value is an Array
 -  *
 -  * @param {Object} val The value to test
 -  * @returns {boolean} True if value is an Array, otherwise false
 -  */
 - export function isArray (val) {
 -   return toString.call(val) === '[object Array]'
 - }
 - 
 - 
 - /**
 -  * Determine if a value is an Object
 -  *
 -  * @param {Object} val The value to test
 -  * @returns {boolean} True if value is an Object, otherwise false
 -  */
 - export function isObject (val) {
 -   return val !== null && typeof val === 'object'
 - }
 - 
 - /**
 -  * Determine if a value is a Date
 -  *
 -  * @param {Object} val The value to test
 -  * @returns {boolean} True if value is a Date, otherwise false
 -  */
 - export function isDate (val) {
 -   return toString.call(val) === '[object Date]'
 - }
 - 
 - /**
 -  * Determine if a value is a URLSearchParams object
 -  *
 -  * @param {Object} val The value to test
 -  * @returns {boolean} True if value is a URLSearchParams object, otherwise false
 -  */
 - export function isURLSearchParams (val) {
 -   return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams
 - }
 - 
 - 
 - /**
 -  * Iterate over an Array or an Object invoking a function for each item.
 -  *
 -  * If `obj` is an Array callback will be called passing
 -  * the value, index, and complete array for each item.
 -  *
 -  * If 'obj' is an Object callback will be called passing
 -  * the value, key, and complete object for each property.
 -  *
 -  * @param {Object|Array} obj The object to iterate
 -  * @param {Function} fn The callback to invoke for each item
 -  */
 - export function forEach (obj, fn) {
 -   // Don't bother if no value provided
 -   if (obj === null || typeof obj === 'undefined') {
 -     return
 -   }
 - 
 -   // Force an array if not already something iterable
 -   if (typeof obj !== 'object') {
 -     /*eslint no-param-reassign:0*/
 -     obj = [obj]
 -   }
 - 
 -   if (isArray(obj)) {
 -     // Iterate over array values
 -     for (var i = 0, l = obj.length; i < l; i++) {
 -       fn.call(null, obj[i], i, obj)
 -     }
 -   } else {
 -     // Iterate over object keys
 -     for (var key in obj) {
 -       if (Object.prototype.hasOwnProperty.call(obj, key)) {
 -         fn.call(null, obj[key], key, obj)
 -       }
 -     }
 -   }
 - }
 - 
 - /**
 -  * 是否为boolean 值
 -  * @param val
 -  * @returns {boolean}
 -  */
 - export function isBoolean(val) {
 -   return typeof val === 'boolean'
 - }
 - 
 - /**
 -  * 是否为真正的对象{} new Object
 -  * @param {any} obj - 检测的对象
 -  * @returns {boolean}
 -  */
 - export function isPlainObject(obj) {
 -   return Object.prototype.toString.call(obj) === '[object Object]'
 - }
 - 
 - 
 - 
 - /**
 -  * Function equal to merge with the difference being that no reference
 -  * to original objects is kept.
 -  *
 -  * @see merge
 -  * @param {Object} obj1 Object to merge
 -  * @returns {Object} Result of all merge properties
 -  */
 - export function deepMerge(/* obj1, obj2, obj3, ... */) {
 -   let result = {}
 -   function assignValue(val, key) {
 -     if (typeof result[key] === 'object' && typeof val === 'object') {
 -       result[key] = deepMerge(result[key], val)
 -     } else if (typeof val === 'object') {
 -       result[key] = deepMerge({}, val)
 -     } else {
 -       result[key] = val
 -     }
 -   }
 -   for (let i = 0, l = arguments.length; i < l; i++) {
 -     forEach(arguments[i], assignValue)
 -   }
 -   return result
 - }
 - 
 - export function isUndefined (val) {
 -   return typeof val === 'undefined'
 - }
 
 
  |