您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

recharge.vue 3.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  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 } 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. state.form.cardNumber = option.cardNumber;
  45. if (option.value) {
  46. state.form = JSON.parse(decodeURIComponent(option.value))
  47. }
  48. });
  49. const goRecharge = () => {
  50. for (var i in state.form) {
  51. if (!state.form[i]) {
  52. msg('请把信息填写完整!')
  53. return;
  54. }
  55. }
  56. const options = {
  57. type: 2,
  58. data: {
  59. 'accountId': state.form.name, //账户编号
  60. 'fee': state.form.fee, //公司营业执照统一社会信用代码
  61. 'bankCardId': state.form.cardNumber, //对公名称
  62. 'imageUrl': state.form.url, //密码
  63. },
  64. method: "POST",
  65. showLoading: true,
  66. };
  67. request(queryRecharge, options)
  68. .then((res) => {
  69. let data = stringToJson(res.bizContent)
  70. console.log("充值成功", data)
  71. })
  72. .catch((err) => {
  73. console.log(err);
  74. });
  75. }
  76. const goBank = () => {
  77. const params = encodeURIComponent(JSON.stringify(state.form));
  78. uni.redirectTo({
  79. //关闭当前页面,跳转到应用内的某个页面。
  80. url: `/subpackage/personal-center/setting/bank-card/bank-card?choiceCard=1&value=${params}`
  81. });
  82. // navTo(`/subpackage/personal-center/setting/bank-card/bank-card?choiceCard=1`)
  83. }
  84. const cardDbImageOcr = (val : any) => {
  85. var imageType = val;
  86. uni.chooseImage({
  87. count: 1, //只能选取一张照片
  88. sizeType: ["original", "compressed"], //可以指定是原图还是压缩图,默认二者都有
  89. sourceType: ["camera", "album"], //从相册选择
  90. success: function (res) {
  91. uploadFile(res.tempFilePaths[0], "", "").then((data) => {
  92. state.form.url = data;
  93. })
  94. },
  95. });
  96. };
  97. </script>
  98. <style scoped>
  99. .wrap {
  100. padding: 0 30rpx;
  101. }
  102. /deep/.u-form-item--right__content__slot {
  103. display: flex;
  104. justify-content: space-between;
  105. }
  106. image {
  107. width: 200rpx;
  108. height: 200rpx;
  109. }
  110. button {
  111. width: 75%;
  112. height: 80rpx;
  113. margin-top: 450rpx;
  114. background: linear-gradient(-90deg, #43a1e0 0%, #13e7c1 100%);
  115. border-radius: 40rpx;
  116. font-size: 32rpx;
  117. font-weight: 400;
  118. color: #ffffff;
  119. line-height: 80rpx;
  120. }
  121. .card {
  122. width: 100%;
  123. display: flex;
  124. justify-content: space-between;
  125. }
  126. </style>