newRequest.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. import store from '../store'
  2. let service = {
  3. // baseURL: store.state.baseURL, // 请求头
  4. baseURL: '', // 请求头
  5. header: {
  6. 'Content-Type': "application/x-www-form-urlencoded"
  7. },
  8. // 请求拦截器
  9. interceptors: {
  10. // 安装请求前拦截
  11. request: function(success, iserror) {
  12. service.request.success = success;
  13. service.request.error = iserror;
  14. },
  15. // 安装请求完成后拦截
  16. response: function(success, iserror) {
  17. service.response.success = success;
  18. service.response.error = iserror;
  19. }
  20. },
  21. // 请求前拦截
  22. request: {
  23. // 回调成功执行方法
  24. success: function(e) {
  25. return e
  26. },
  27. // 回调失败
  28. error: function(e) {
  29. return e
  30. }
  31. },
  32. // 请求完成后拦截
  33. response: {
  34. // 回调成功执行方法
  35. success: function(e) {
  36. return e
  37. },
  38. // 回调失败
  39. error: function(e) {
  40. return e
  41. }
  42. },
  43. // 开始请求
  44. open: async function(data) {
  45. return await new Promise(function(resolve, reject) {
  46. let requestData = ''; //保存处理完成后请求数据
  47. //console.log(data);
  48. // 请求前数据处理
  49. requestData = service.request.success(data);
  50. // console.log('requestData', requestData)
  51. // 数据复制用于请求
  52. uni.request({
  53. url: service.baseURL + requestData.url,
  54. method: requestData.method || 'GET',
  55. data: requestData.data,
  56. header: data.header || service.header,
  57. success: res => {
  58. if (res.statusCode == 200) {
  59. try {
  60. resolve(service.response.success(res));
  61. } catch (e) {
  62. service.response.error(e)
  63. }
  64. }
  65. },
  66. // 请求失败数据处理
  67. fail: (err) => {
  68. service.response.error(err)
  69. }
  70. });
  71. })
  72. },
  73. // 上传文件
  74. upFilse: async function(data) {
  75. return await new Promise(function(resolve, reject) {
  76. let requestData = ''; //保存处理完成后请求数据
  77. try {
  78. // 请求前数据处理
  79. requestData = service.request.success(data);
  80. } catch (e) {
  81. // 请求报错拦截
  82. service.request.error(e);
  83. }
  84. let config = {
  85. // 上传图片的API
  86. upload_img_url: service.baseURL + requestData.url
  87. }
  88. let Uploader = {
  89. // 选择图片
  90. choose(num) {
  91. return new Promise((resolve, reject) => {
  92. uni.chooseImage({
  93. count: num,
  94. sourceType: ['album'], //从相册选择
  95. sizeType:'compressed',
  96. success(res) {
  97. // console.log(res);
  98. // 缓存文件路径
  99. resolve(res.tempFilePaths)
  100. },
  101. fail(err) {
  102. console.log(err)
  103. reject(err)
  104. }
  105. })
  106. })
  107. },
  108. // 上传图片
  109. upload_one(path) {
  110. return new Promise((resolve, reject) => {
  111. uni.showLoading({
  112. title: '上传中'
  113. })
  114. uni.uploadFile({
  115. url: config.upload_img_url, //仅为示例,非真实的接口地址
  116. filePath: path,
  117. name: 'file',
  118. header: {
  119. "Authori-zation": 'Bearer ' + uni.getStorageSync('token')
  120. },
  121. success: (uploadFileRes) => {
  122. if ("string" === typeof uploadFileRes.data) {
  123. resolve(JSON.parse(uploadFileRes.data).data)
  124. } else {
  125. resolve(uploadFileRes.data.data)
  126. }
  127. },
  128. complete() {
  129. uni.hideLoading()
  130. }
  131. });
  132. })
  133. },
  134. // 上传多个图片
  135. upload(path_arr) {
  136. let num = path_arr.length;
  137. return new Promise(async (resolve, reject) => {
  138. let img_urls = []
  139. for (let i = 0; i < num; i++) {
  140. let img_url = await this.upload_one(path_arr[i]);
  141. img_urls.push(img_url)
  142. };
  143. resolve(img_urls)
  144. })
  145. },
  146. // 触发上传图片事件
  147. choose_and_upload(num) {
  148. return new Promise(async (resolve, reject) => {
  149. // 选择图片
  150. let path_arr = await this.choose(num);
  151. // 上传图片
  152. await this.upload(path_arr).then((e) => {
  153. resolve(e);
  154. }).catch((e) => {
  155. reject(e)
  156. });
  157. })
  158. }
  159. };
  160. Uploader.choose_and_upload(1).then((e) => {
  161. resolve(e);
  162. }).catch((e) => {
  163. console.log(e);
  164. })
  165. })
  166. },
  167. };
  168. export default service