caimeiApi.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. /**
  2. * @Time 2019-12-12
  3. * @Author Zhengjingyi
  4. * @Action 全局公共方法
  5. */
  6. import requestUrl from '@/services/ajax.env.js'
  7. const caimeiApi = {
  8. /**
  9. * @封装公共get数据请求方法无加载动画
  10. * @方法参数:请求地址,请求后台需要的参数字段,回调函数
  11. * @自定义请求头信息
  12. */
  13. get:function(url,data,callback){
  14. uni.request({
  15. url: requestUrl + url,
  16. data:data,
  17. header: {
  18. 'Accept': 'application/json',
  19. 'Content-Type': 'application/x-www-form-urlencoded',
  20. 'X-Token': uni.getStorageSync('token') ? uni.getStorageSync('token') : 'token',
  21. 'cookie': uni.getStorageSync('sessionid')
  22. },
  23. method: 'GET',
  24. success: (response) => {
  25. if(response.statusCode !== 200){
  26. uni.showToast({icon: 'none',title:'服务器连接错误',duration: 2000})
  27. callback(response.statusCode)
  28. }else{
  29. callback(response.data)
  30. }
  31. },
  32. fail: (error) => {
  33. if (error) {
  34. uni.showToast({icon: 'none',title: '网络错误,请稍后重试',duration: 2000})
  35. }
  36. }
  37. })
  38. },
  39. /**
  40. * @封装公共get数据请求方法有加载动画
  41. * @方法参数:请求地址,请求后台需要的参数字段,回调函数
  42. * @自定义请求头信息
  43. */
  44. lodingGet:function(url,data,callback){
  45. uni.showLoading({mask: true,title:'加载中~',})
  46. uni.request({
  47. url: requestUrl + url,
  48. data:data,
  49. header: {
  50. 'Accept': 'application/json',
  51. 'Content-Type': 'application/x-www-form-urlencoded',
  52. 'X-Token': uni.getStorageSync('token') ? uni.getStorageSync('token') : 'token',
  53. 'cookie': uni.getStorageSync('sessionid')
  54. },
  55. method: 'GET',
  56. success: (response) => {
  57. if(response.statusCode !== 200){
  58. uni.showToast({icon: 'none',title: '服务器连接错误',duration: 2000})
  59. callback(response.statusCode)
  60. }else{
  61. callback(response.data)
  62. }
  63. },
  64. fail: (error) => {
  65. if (error) {
  66. uni.showToast({icon: 'none',title: '网络错误,请稍后重试',duration: 2000})
  67. }
  68. },
  69. complete: () => {
  70. setTimeout(function () {
  71. uni.hideLoading()
  72. }, 250)
  73. }
  74. })
  75. },
  76. /**
  77. * @封装公共post数据请求方法
  78. * @方法参数:请求地址,请求后台需要的参数字段,回调函数
  79. */
  80. post:function(url,data,loadingStatus,callback){
  81. if(loadingStatus){uni.showLoading({mask: true,title:'加载中~'})}
  82. uni.request({
  83. url: requestUrl+url,
  84. data:data,
  85. header: {
  86. 'Accept': 'application/json',
  87. 'Content-Type': 'application/x-www-form-urlencoded',
  88. 'X-Token': uni.getStorageSync('token') ? uni.getStorageSync('token') : 'token',
  89. 'cookie': uni.getStorageSync('sessionid')
  90. },
  91. method: 'POST',
  92. success: (response) => {
  93. if(loadingStatus){uni.hideLoading()}
  94. const result = response.data
  95. callback(result)
  96. },
  97. fail: (error) => {
  98. uni.hideLoading()
  99. if (error) {
  100. uni.showToast({icon: 'none',title: '网络错误,请稍后重试',duration: 2000})
  101. }
  102. }
  103. })
  104. },
  105. getComStorage:function(key){// 获取本地Storage
  106. return new Promise(function(resolve,reject) {
  107. uni.getStorage({
  108. key: key,
  109. success: function (res){
  110. resolve(res.data)
  111. },
  112. fail: function(res){
  113. reject(false)
  114. }
  115. })
  116. })
  117. },
  118. setStorage:function(key,data){// 存储本地Storage
  119. return new Promise(function(resolve,reject) {
  120. uni.setStorage({
  121. key: key,
  122. data:data,
  123. success: function (res){
  124. }
  125. })
  126. })
  127. },
  128. getStorage:function(){// 获取本地userInfo
  129. return new Promise(function(resolve,reject) {
  130. uni.getStorage({
  131. key: 'userInfo',
  132. success: function (res){
  133. resolve(res.data)
  134. },
  135. fail: function(res){
  136. reject(false)
  137. }
  138. })
  139. })
  140. },
  141. getStorageAddressKey:function(){// 获取本地地址信息
  142. return new Promise(function(resolve,reject) {
  143. uni.getStorage({
  144. key: 'address_key',
  145. success: function (res){
  146. resolve(res.data)
  147. }
  148. })
  149. })
  150. },
  151. loginStatus:function(){
  152. // 获取用户是否登陆 1:已登陆,否则未登陆
  153. return new Promise(function(resolve,reject) {
  154. uni.getStorage({
  155. key: 'userInfo',
  156. success: function (res){
  157. if(res.data.code == '1'){
  158. resolve(true)
  159. } else {
  160. resolve(false)
  161. }
  162. }
  163. })
  164. })
  165. },
  166. navToListPage:function({type,value,id,lType} = {}){
  167. // 跳转到列表页
  168. if(lType=='4'){
  169. const pages = getCurrentPages()
  170. const prevPage = pages[pages.length-2]
  171. prevPage.refresh = true
  172. prevPage.listData = {
  173. type: type,
  174. from: value,
  175. id: id
  176. }
  177. uni.navigateBack({
  178. delta: 1
  179. })
  180. }else{
  181. uni.navigateTo({
  182. url:`/pages/goods/goods?type=${type}&from=${value}&id=${id}`
  183. })
  184. }
  185. },
  186. navigateToGoods:function({type,value,id,lType} = {}){
  187. // 跳转到列表页
  188. if(lType=='4'){
  189. const pages = getCurrentPages()
  190. const prevPage = pages[pages.length-2]
  191. prevPage.refresh = true
  192. prevPage.listData = {
  193. type: type,
  194. from: value,
  195. id: id
  196. }
  197. uni.navigateBack({
  198. delta: 1
  199. })
  200. }else{
  201. uni.navigateTo({
  202. url:`/pages/goods/goods-classify?type=${type}&from=${value}&id=${id}`
  203. })
  204. }
  205. },
  206. FlooryNavigateTo:function(pros){
  207. if(pros.listType == 1){
  208. if(pros.product.productCategory == '1'){
  209. uni.navigateTo({
  210. url:`/pages/goods/product?id=${pros.product.productID}`
  211. })
  212. }else{
  213. uni.navigateTo({
  214. url:`/second/pages/product/product-details?id=${pros.product.productID}`
  215. })
  216. }
  217. }else{
  218. /**
  219. * 页面跳转类型
  220. * 1、二级页面,2、搜索项目仪器,3、直播页面,4、自由页面,5、商品详情,6、仪器项目详情,7、供应商主页
  221. * 8、专题活动页,9、二手市场介绍,10、二手商品列表,11、二手商品发布,12、商品搜索,13、信息详情
  222. * 14、品牌招商介绍页,15、维修保养介绍页,16、首页,17、注册页,18、信息中心,19、供应商列表
  223. **/
  224. if(pros.linkType){
  225. console.log(pros.linkType)
  226. const typeMap = {
  227. 1:`/pages/goods/goods-instrument?linkId=${pros.linkParam.id}`,
  228. 2:`/pages/goods/instrument-details?id=${pros.linkParam.id}`,
  229. 4:`/h5/pages/activity/activity?title=${pros.crmTitle}&link=${pros.crmLink}`,
  230. 5:`/pages/goods/product?id=${pros.linkParam.id}`,
  231. // 7:`/supplier/pages/user/my-shop?shopId=${pros.linkParam.id}`,
  232. 8:'/h5/pages/activity/activity-list',
  233. 9:'/second/pages/form/introduce',
  234. 10:'/second/pages/product/product-list',
  235. 11:'/second/pages/form/form',
  236. 12:`/search/pages/search/search?keyWord=${pros.linkParam.keyword}`,
  237. 13:`/h5/pages/article/path?link=${pros.link}`,
  238. 14:`/h5/pages/article/path?link=${pros.link}`,
  239. 15:`/h5/pages/article/path?link=${pros.link}`,
  240. // '-1':`/h5/pages/article/path?link=${pros.link}`,
  241. 17:'/pages/login/register-select',
  242. 18:`/h5/pages/article/path?link=${pros.link}`,
  243. 19:`/search/pages/search/search-supplier?keyWord=${pros.linkParam.keyword}`,
  244. 21:'/h5/pages/activity/meobohui'
  245. }
  246. const url = typeMap[pros.linkType]
  247. uni.navigateTo({
  248. url:url
  249. })
  250. }
  251. }
  252. },
  253. BannerNavigateTo:function(linkType,linkId,linkHref,keyword){//楼层跳转判断
  254. if(linkType){
  255. const typeMap = {
  256. 1:`/pages/goods/goods-instrument?linkId=${linkId}`,
  257. 2:`/pages/goods/instrument-details?id=${linkId}`,
  258. 4:`/h5/pages/activity/activity?id=${linkId}`,
  259. 5:`/pages/goods/product?id=${linkId}`,
  260. // 7:`/supplier/pages/user/my-shop?shopId=${linkId}`,
  261. 8:'/h5/pages/activity/activity-list',
  262. 9:'/second/pages/form/introduce',
  263. 10:'/second/pages/product/product-list',
  264. 11:'/second/pages/form/form',
  265. 12:`/search/pages/search/search?keyWord=${keyword}`,
  266. 13:`/h5/pages/article/path?link=${linkHref}`,
  267. 14:`/h5/pages/article/path?link=${linkHref}`,
  268. 15:`/h5/pages/article/path?link=${linkHref}`,
  269. 17:'/pages/login/register-select',
  270. 18:`/h5/pages/article/path?link=${linkHref}`,
  271. 19:`/search/pages/search/search-supplier?keyWord=${keyword}`,
  272. 21:'/h5/pages/activity/meobohui',
  273. // '-1':`/h5/pages/article/path?link=${pros.link}`
  274. }
  275. const url = typeMap[linkType]
  276. uni.navigateTo({
  277. url:url
  278. })
  279. }
  280. },
  281. navigateTo:function(url){
  282. //路由跳转:页面之间路由跳转
  283. uni.navigateTo({
  284. url:url
  285. })
  286. },
  287. redirectTo:function(url){
  288. //路由跳转:关闭当前页跳转到新页面
  289. uni.redirectTo({
  290. url:url
  291. })
  292. },
  293. switchTabTo:function(url){
  294. //路由跳转:底部 tab页
  295. uni.switchTab({
  296. url:url
  297. })
  298. },
  299. isNumber:function(value){//验证是否为数字
  300. var patrn = /^(-)?\d+(\.\d+)?$/
  301. if (patrn.exec(value) == null || value == '') {
  302. return false
  303. } else {
  304. return true
  305. }
  306. },
  307. getWindowHeight:function(){
  308. // 获取窗口高度
  309. const {windowHeight, pixelRatio} = wx.getSystemInfoSync()
  310. return windowHeight
  311. },
  312. adaptRichTextImg:function(res){
  313. /**
  314. *@富文本实现图片自适应
  315. *@style再添加自适应样式
  316. */
  317. const html = res.replace(/<img[^>]*>/gi,function(match,capture){
  318. let match1 = match.replace(/<img*/gi, '<img style="width:100% !important;height:auto !important;float:left !important;"'),
  319. results = match1.replace(/style=/gi, 'style="width:100%;height:auto;float:left;"')
  320. return results
  321. })
  322. return html
  323. },
  324. FormatMoney:function(num){
  325. // 金额千分位
  326. return num.toString().replace(/\d+/, function (n) { // 先提取整数部分
  327. return n.replace(/(\d)(?=(\d{3})+$)/g, function ($1) { // 对整数部分添加分隔符
  328. return $1 + ','
  329. })
  330. })
  331. },
  332. formatDate:function(){
  333. //获取当前时间
  334. let date = new Date()
  335. let y = date.getFullYear()
  336. let MM = date.getMonth() + 1
  337. MM = MM < 10 ? ('0' + MM) : MM
  338. let d = date.getDate()
  339. d = d < 10 ? ('0' + d) : d
  340. let h = date.getHours()
  341. h = h < 10 ? ('0' + h) : h
  342. let m = date.getMinutes()
  343. m = m < 10 ? ('0' + m) : m
  344. let s = date.getSeconds()
  345. s = s < 10 ? ('0' + s) : s
  346. return y + '-' + MM + '-' + d + ' ' + h + ':' + m + ':' + s
  347. },
  348. regexSets:function() {
  349. let sets = {
  350. 'companyName': /^[\u4e00-\u9fa5\(\)()\s\da-zA-Z&]{2,50}$/gi,
  351. 'phoneAndTelephone': /^([1]\d{10}|([\((]?0[0-9]{2,3}[)\)]?[-]?)?([2-9][0-9]{6,7})+(\-[0-9]{1,4})?)$/,
  352. 'bankNum': /^([1-9]{1})(\d{18})$/,
  353. 'invalidChar': /^[\s\u4e00-\u9fa5a-z0-9_-]{0,}$/
  354. }
  355. return sets
  356. },
  357. timestampToTime:function(timestamp) {
  358. // 时间戳转日期
  359. let date = new Date(timestamp * 1000)//时间戳为10位需*1000,时间戳为13位的话不需乘1000
  360. let Y = date.getFullYear() + '-'
  361. let M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '-'
  362. let D = (date.getDate() < 10 ? '0'+date.getDate() : date.getDate()) + ' '
  363. let h = (date.getHours() < 10 ? '0'+date.getHours() : date.getHours()) + ':'
  364. let m = (date.getMinutes() < 10 ? '0'+date.getMinutes() : date.getMinutes()) + ':'
  365. let s = (date.getSeconds() < 10 ? '0'+date.getSeconds() : date.getSeconds())
  366. return `${Y}${M}${D}${h}${m}${s}`
  367. }
  368. }
  369. /**
  370. *@导出
  371. */
  372. module.exports = {
  373. get: caimeiApi.get,
  374. post: caimeiApi.post,
  375. lodingGet: caimeiApi.lodingGet,
  376. isNumber: caimeiApi.isNumber,
  377. FormatMoney: caimeiApi.FormatMoney,
  378. navigateTo: caimeiApi.navigateTo,
  379. redirectTo: caimeiApi.redirectTo,
  380. switchTabTo: caimeiApi.switchTabTo,
  381. formatDate: caimeiApi.formatDate,
  382. loginStatus: caimeiApi.loginStatus,
  383. setStorage: caimeiApi.setStorage,
  384. getStorage: caimeiApi.getStorage,
  385. getComStorage: caimeiApi.getComStorage,
  386. navToListPage: caimeiApi.navToListPage,
  387. navigateToGoods: caimeiApi.navigateToGoods,
  388. getWindowHeight: caimeiApi.getWindowHeight,
  389. adaptRichTextImg: caimeiApi.adaptRichTextImg,
  390. getStorageAddressKey: caimeiApi.getStorageAddressKey,
  391. regexSets: caimeiApi.regexSets,
  392. timestampToTime: caimeiApi.timestampToTime,
  393. BannerNavigateTo:caimeiApi.BannerNavigateTo,
  394. FlooryNavigateTo:caimeiApi.FlooryNavigateTo
  395. }