util.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  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. //四舍五入保留2位小数(不够位数,则用0替补)
  59. util.keepTwoDecimalFull = num => {
  60. var result = parseFloat(num)
  61. if (isNaN(result)) {
  62. return false
  63. }
  64. result = Math.round(num * 100) / 100
  65. var s_x = result.toString()
  66. var pos_decimal = s_x.indexOf('.')
  67. if (pos_decimal < 0) {
  68. pos_decimal = s_x.length
  69. s_x += '.'
  70. }
  71. while (s_x.length <= pos_decimal + 2) {
  72. s_x += '0'
  73. }
  74. return s_x
  75. }
  76. /**
  77. * 数组去重
  78. * @param {Array} arr 源数组
  79. *
  80. * @return {Array} newArr 去重后的数组
  81. */
  82. util.uniqueArray = (arr)=>{
  83. return [...new Set(arr)]
  84. }
  85. //获取某一个页面上下文 context
  86. util.getPageCtx = (idx = 0) => {
  87. let pages = getCurrentPages()
  88. if (pages.length > 0) {
  89. return pages[pages.length - 1 - idx] || {}
  90. }
  91. return {}
  92. }
  93. //获取当前页面路由
  94. util.getCurrentRoute = () => {
  95. let page = util.getPageCtx()
  96. if (page.route) {
  97. return page.route
  98. }
  99. return ''
  100. }
  101. //回到上一页刷新页面
  102. util.isReloadAndBack = () => {
  103. let prePage=util.getPageCtx(1)
  104. prePage.setData({
  105. "reload":true
  106. })
  107. uni.navigateBack({
  108. delta:1
  109. })
  110. }
  111. //onshow方法通过刷新mescroll数据
  112. util.reload = (mescroll) => {
  113. let page= util.getPageCtx()
  114. if (page.data.reload) {
  115. mescroll.resetUpScroll();
  116. page.data.reload=false
  117. }
  118. }
  119. export default util