util.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. import simpleCache from './cache.js'
  2. import dateTime from './dateTime.js'
  3. //工具类
  4. let util = {}
  5. //预览图片
  6. // this.$util.preview('http://....png')
  7. // this.$util.preview('../../test.png')
  8. // this.$util.preview(['http://....png', '../../test.png'])
  9. util.preview=async (src)=> {
  10. const urls = typeof src === 'string' ? [src] : src
  11. const filePath = async src => src.match(/^http/) ? src : (await uni.compressImage({ src, quality: 100 }))[1].tempFilePath
  12. for (let i = 0; i < urls.length; i++) {
  13. urls[i] = await filePath(urls[i])
  14. }
  15. uni.previewImage({ urls })
  16. },
  17. //复制
  18. util.copy=content=>{
  19. uni.setClipboardData({ data: content });
  20. }
  21. util.calculateDistance=(lat1, lng1, lat2, lng2)=> {
  22. console.log(lat1, lng1, lat2, lng2)
  23. var radLat1 = lat1 * Math.PI / 180.0;
  24. var radLat2 = lat2 * Math.PI / 180.0;
  25. var a = radLat1 - radLat2;
  26. var b = lng1 * Math.PI / 180.0 - lng2 * Math.PI / 180.0;
  27. var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +
  28. Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));
  29. s = s * 6378.137;
  30. s = Math.round(s * 10000) / 10;//单位米
  31. return s
  32. },
  33. util.showModal=(content,title='提示')=>{
  34. return new Promise((resolve,reject)=>{
  35. uni.showModal({
  36. title: title,
  37. content: content,
  38. success: (res)=>{
  39. resolve(res)
  40. }
  41. });
  42. })
  43. }
  44. //拨打电话
  45. util.callPhone=(phone)=>{
  46. uni.showModal({
  47. title: '提示',
  48. content: `确定要拨打电话:${phone}吗?`,
  49. success: function (res) {
  50. if (res.confirm) {
  51. uni.makePhoneCall({
  52. phoneNumber: phone //仅为示例
  53. });
  54. }
  55. }
  56. });
  57. }
  58. /**
  59. * 数组去重
  60. * @param {Array} arr 源数组
  61. *
  62. * @return {Array} newArr 去重后的数组
  63. */
  64. util.uniqueArray = (arr)=>{
  65. return [...new Set(arr)]
  66. }
  67. //获取某一个页面上下文 context
  68. util.getPageCtx = (idx = 0) => {
  69. let pages = getCurrentPages()
  70. if (pages.length > 0) {
  71. return pages[pages.length - 1 - idx] || {}
  72. }
  73. return {}
  74. }
  75. //获取当前页面路由
  76. util.getCurrentRoute = () => {
  77. let page = util.getPageCtx()
  78. if (page.route) {
  79. return page.route
  80. }
  81. return ''
  82. }
  83. //回到上一页刷新页面
  84. util.isReloadAndBack = () => {
  85. let prePage=util.getPageCtx(1)
  86. prePage.setData({
  87. "reload":true
  88. })
  89. uni.navigateBack({
  90. delta:1
  91. })
  92. }
  93. //onshow方法通过刷新mescroll数据
  94. util.reload = (mescroll) => {
  95. let page= util.getPageCtx()
  96. if (page.data.reload) {
  97. mescroll.resetUpScroll();
  98. page.data.reload=false
  99. }
  100. }
  101. // 刷新当前页面
  102. util.refreshPage = () => {
  103. const pages = getCurrentPages()
  104. const currentPage = pages[pages.length - 1]
  105. const path = '/' + currentPage.route + vm.$u.queryParams(currentPage.options)
  106. if (vm.$u.test.contains(currentPage.route, 'tabbar')) {
  107. uni.reLaunch({
  108. url: path,
  109. fail: (err) => {
  110. console.log(err)
  111. }
  112. })
  113. } else {
  114. uni.redirectTo({
  115. url: path,
  116. fail: (err) => {
  117. console.log(err)
  118. }
  119. })
  120. }
  121. }
  122. export default util