Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

recharge.vue 3.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <template>
  2. <view class='wrap'>
  3. <u-form :model="form" ref="form1" label-width=160 border-bottom=false>
  4. <u-form-item label="用户名" border-bottom=true>
  5. <u-input placeholder='请输入用户名' type="text" v-model="state.form.name" />
  6. </u-form-item>
  7. <u-form-item label="充值金额">
  8. <u-input placeholder='请输入充值金额' type="text" v-model="state.form.fee" />
  9. </u-form-item>
  10. <u-form-item label="银行卡">
  11. <view class='card' @click='goBank()'>
  12. <u-input placeholder='请输入银行卡号' v-model="state.form.cardNumber" type="text" disabled />
  13. <u-icon name="arrow-right" color='#ccc'></u-icon>
  14. </view>
  15. </u-form-item>
  16. <u-form-item label="充值凭证">
  17. <view class='item' @click="cardDbImageOcr(1)">
  18. <image v-if="!state.form.url" class="icon" :src="`${$imgUrl}applyCard/renxiang.png`">
  19. </image>
  20. <image v-else class="icon" :src="state.form.url"></image>
  21. </view>
  22. </u-form-item>
  23. <button @click='goRecharge()'>充值</button>
  24. </u-form>
  25. </view>
  26. </template>
  27. <script setup lang="ts">
  28. import { reactive } from "vue";
  29. import { etcOcrCard, queryRecharge } from "@/utils/network/api.js";
  30. import { request } from "@/utils/network/request.js";
  31. import { stringToJson } from "@/utils/network/encryption.js";
  32. import { navTo, uploadFile, msg } from "@/utils/utils";
  33. import { onLoad } from "@dcloudio/uni-app";
  34. const state = reactive({
  35. form: {
  36. name: '',//对公用户登录名
  37. fee: '',
  38. cardNumber: '',
  39. url: '',
  40. }
  41. })
  42. onLoad((option : any) => {
  43. console.log("option", option.cardNumber)
  44. if (option.value) {
  45. state.form = JSON.parse(decodeURIComponent(option.value))
  46. }
  47. if (option.cardNumber) {
  48. state.form.cardNumber = option.cardNumber;
  49. }
  50. if (option.name) {
  51. state.form.name = option.name
  52. }
  53. });
  54. const goRecharge = () => {
  55. for (var i in state.form) {
  56. if (!state.form[i]) {
  57. msg('请把信息填写完整!')
  58. return;
  59. }
  60. }
  61. const options = {
  62. type: 2,
  63. data: {
  64. 'accountId': state.form.name, //账户编号
  65. 'fee': state.form.fee, //公司营业执照统一社会信用代码
  66. 'bankCardId': state.form.cardNumber, //对公名称
  67. 'imageUrl': state.form.url, //密码
  68. },
  69. method: "POST",
  70. showLoading: true,
  71. };
  72. request(queryRecharge, options)
  73. .then((res) => {
  74. let data = stringToJson(res.bizContent)
  75. if (data.status == 1) {
  76. uni.navigateBack({
  77. delta: 1
  78. })
  79. }
  80. console.log("充值成功", data)
  81. })
  82. .catch((err) => {
  83. console.log(err);
  84. });
  85. }
  86. const goBank = () => {
  87. const params = encodeURIComponent(JSON.stringify(state.form));
  88. uni.redirectTo({
  89. //关闭当前页面,跳转到应用内的某个页面。
  90. url: `/subpackage/personal-center/setting/bank-card/bank-card?choiceCard=1&value=${params}`
  91. });
  92. }
  93. const cardDbImageOcr = (val : any) => {
  94. var imageType = val;
  95. uni.chooseImage({
  96. count: 1, //只能选取一张照片
  97. sizeType: ["original", "compressed"], //可以指定是原图还是压缩图,默认二者都有
  98. sourceType: ["camera", "album"], //从相册选择
  99. success: function (res) {
  100. uploadFile(res.tempFilePaths[0], "", "").then((data) => {
  101. state.form.url = data;
  102. })
  103. },
  104. });
  105. };
  106. </script>
  107. <style scoped>
  108. .wrap {
  109. padding: 0 30rpx;
  110. }
  111. /deep/.u-form-item--right__content__slot {
  112. display: flex;
  113. justify-content: space-between;
  114. }
  115. image {
  116. width: 200rpx;
  117. height: 200rpx;
  118. }
  119. button {
  120. width: 75%;
  121. height: 80rpx;
  122. margin-top: 450rpx;
  123. background: linear-gradient(-90deg, #43a1e0 0%, #13e7c1 100%);
  124. border-radius: 40rpx;
  125. font-size: 32rpx;
  126. font-weight: 400;
  127. color: #ffffff;
  128. line-height: 80rpx;
  129. }
  130. .card {
  131. width: 100%;
  132. display: flex;
  133. justify-content: space-between;
  134. }
  135. </style>