| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 | 
							- // 引入全局mixin
 
- import mixin from './libs/mixin/mixin.js'
 
- // 引入关于是否mixin集成小程序分享的配置
 
- // import wxshare from './libs/mixin/mpShare.js'
 
- // 全局挂载引入http相关请求拦截插件
 
- import http from './libs/request'
 
- function wranning(str) {
 
- 	// 开发环境进行信息输出,主要是一些报错信息
 
- 	// 这个环境的来由是在程序编写时候,点击hx编辑器运行调试代码的时候,详见:
 
- 	// 	https://uniapp.dcloud.io/frame?id=%e5%bc%80%e5%8f%91%e7%8e%af%e5%a2%83%e5%92%8c%e7%94%9f%e4%ba%a7%e7%8e%af%e5%a2%83
 
- 	if (process.env.NODE_ENV === 'development') {
 
- 		console.warn(str)
 
- 	}
 
- }
 
- // 尝试判断在根目录的/store中是否有$u.mixin.js,此文件uView默认为需要挂在到全局的vuex的state变量
 
- // HX2.6.11版本,放到try中,控制台依然会警告,暂时不用此方式,
 
- // let vuexStore = {};
 
- // try {
 
- // 	vuexStore = require("@/store/$u.mixin.js");
 
- // } catch (e) {
 
- // 	//TODO handle the exception
 
- // }
 
- // post类型对象参数转为get类型url参数
 
- import queryParams from './libs/function/queryParams.js'
 
- // 路由封装
 
- import route from './libs/function/route.js'
 
- // 时间格式化
 
- import timeFormat from './libs/function/timeFormat.js'
 
- // 时间戳格式化,返回多久之前
 
- import timeFrom from './libs/function/timeFrom.js'
 
- // 颜色渐变相关,colorGradient-颜色渐变,hexToRgb-十六进制颜色转rgb颜色,rgbToHex-rgb转十六进制
 
- import colorGradient from './libs/function/colorGradient.js'
 
- // 生成全局唯一guid字符串
 
- import guid from './libs/function/guid.js'
 
- // 主题相关颜色,info|success|warning|primary|default|error,此颜色已在uview.scss中定义,但是为js中也能使用,故也定义一份
 
- import color from './libs/function/color.js'
 
- // 根据type获取图标名称
 
- import type2icon from './libs/function/type2icon.js'
 
- // 打乱数组的顺序
 
- import randomArray from './libs/function/randomArray.js'
 
- // 对象和数组的深度克隆
 
- import deepClone from './libs/function/deepClone.js'
 
- // 对象深度拷贝
 
- import deepMerge from './libs/function/deepMerge.js'
 
- // 添加单位
 
- import addUnit from './libs/function/addUnit.js'
 
- // 规则检验
 
- import test from './libs/function/test.js'
 
- // 随机数
 
- import random from './libs/function/random.js'
 
- // 去除空格
 
- import trim from './libs/function/trim.js'
 
- // toast提示,对uni.showToast的封装
 
- import toast from './libs/function/toast.js'
 
- // 获取父组件参数
 
- import getParent from './libs/function/getParent.js'
 
- // 获取整个父组件
 
- import $parent from './libs/function/$parent.js'
 
- // 获取sys()和os()工具方法
 
- // 获取设备信息,挂载到$u的sys()(system的缩写)属性中,
 
- // 同时把安卓和ios平台的名称"ios"和"android"挂到$u.os()中,方便取用
 
- import {sys, os} from './libs/function/sys.js'
 
- // 防抖方法
 
- import debounce from './libs/function/debounce.js'
 
- // 节流方法
 
- import throttle from './libs/function/throttle.js'
 
- // 配置信息
 
- import config from './libs/config/config.js'
 
- // 各个需要fixed的地方的z-index配置文件
 
- import zIndex from './libs/config/zIndex.js'
 
- const $u = {
 
- 	queryParams: queryParams,
 
- 	route: route,
 
- 	timeFormat: timeFormat,
 
- 	date: timeFormat, // 另名date
 
- 	timeFrom,
 
- 	colorGradient: colorGradient.colorGradient,
 
- 	colorToRgba: colorGradient.colorToRgba,
 
- 	guid,
 
- 	color,
 
- 	sys,
 
- 	os,
 
- 	type2icon,
 
- 	randomArray,
 
- 	wranning,
 
- 	get: http.get,
 
- 	post: http.post,
 
- 	put: http.put,
 
- 	'delete': http.delete,
 
- 	hexToRgb: colorGradient.hexToRgb,
 
- 	rgbToHex: colorGradient.rgbToHex,
 
- 	test,
 
- 	random,
 
- 	deepClone,
 
- 	deepMerge,
 
- 	getParent,
 
- 	$parent,
 
- 	addUnit,
 
- 	trim,
 
- 	type: ['primary', 'success', 'error', 'warning', 'info'],
 
- 	http,
 
- 	toast,
 
- 	config, // uView配置信息相关,比如版本号
 
- 	zIndex,
 
- 	debounce,
 
- 	throttle,
 
- }
 
- // $u挂载到uni对象上
 
- uni.$u = $u
 
- const install = Vue => {
 
- 	Vue.mixin(mixin) 
 
-   // #ifndef VUE3
 
- 	if (Vue.prototype.openShare) {
 
- 		Vue.mixin(mpShare);
 
- 	}
 
- 	// Vue.mixin(vuexStore);
 
- 	// 时间格式化,同时两个名称,date和timeFormat
 
- 	Vue.filter('timeFormat', (timestamp, format) => {
 
- 		return timeFormat(timestamp, format)
 
- 	})
 
- 	Vue.filter('date', (timestamp, format) => {
 
- 		return timeFormat(timestamp, format)
 
- 	})
 
- 	// 将多久以前的方法,注入到全局过滤器
 
- 	Vue.filter('timeFrom', (timestamp, format) => {
 
- 		return timeFrom(timestamp, format)
 
- 	})
 
- 	Vue.prototype.$u = $u
 
-   // #endif
 
-   // #ifdef VUE3
 
-   Vue.config.globalProperties.$u = $u
 
-   // #endif
 
- }
 
- export default {
 
- 	install
 
- }
 
 
  |