123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214 |
- <template>
- <view class="app">
- <view>
- <view class="label">充值金额(单位:元 ):</view>
- <view><input v-model.number="total_fee" type="number" /></view>
- </view>
- <button type="primary" @click="createOrder('wxpay')">发起支付(微信)</button>
- </view>
- </template>
- <script>
- export default {
- data() {
- return {
- total_fee: 10, // 金额
- transaction_id:"", // 查询订单接口的查询条件
- getOrderRes:{}, // 查询订单支付成功后的返回值
- }
- },
- methods: {
- /**
- * 发起支付(不唤起收银台,手动指定支付方式)
- * 在调用此api前,你应该先创建自己的业务系统订单,并获得订单号 order_no,把order_no当参数传给此api,而示例中为了简化跟支付插件无关的代码,这里直接已时间戳生成了order_no
- */
- createOrder(provider){
- this.http.request({
- url: '/level-one-server/app/WalletManage/topupSave',
- //url: '/level-one-server/app/WalletManage/wxPay/createOrder',
- data: {
- amount: this.total_fee, // 支付金额,单位分 100 = 1元
- goodsName: '服务点充值'
- },
- success: res => {
- this.user.wallet = this.user.wallet + this.total_fee;
- console.log("this.user",this.user)
- uni.setStorageSync('info', this.user);
- uni.showToast({
- title: '充值成功!'
- });
- uni.navigateBack({
- data:1
- });
- }
- });
-
- },
- // 打开查询订单的弹窗
- getOrderPopup(key){
- if (key) {
- this.$refs.getOrderPopup.open();
- } else {
- this.$refs.getOrderPopup.close();
- }
- },
- // 查询支付状态
- async getOrder() {
- this.getOrderRes = {};
- let res = await this.$refs.pay.getOrder({
- //out_trade_no: this.out_trade_no, // 插件支付单号 两者传1个即可
- transaction_id: this.transaction_id, // 第三方单号 两者传1个即可
- await_notify: true
- });
- if (res) {
- this.getOrderRes = res.pay_order;
- let obj = {
- "-1": "已关闭",
- "1": "已支付",
- "0": "未支付",
- "2": "已部分退款",
- "3": "已全额退款"
- };
- uni.showToast({
- title: obj[res.status] || res.errMsg,
- icon: "none"
- });
- }
- },
- // 监听事件 - 支付订单创建成功(此时用户还未支付)
- onCreate(res){
- console.log('create: ', res);
- // 如果只是想生成支付二维码,不需要组件自带的弹窗,则在这里可以获取到支付二维码 qr_code_image
- },
- // 监听事件 - 支付成功
- onSuccess(res){
- console.log('success: ', res);
- if (res.user_order_success) {
- // 代表用户已付款,且你自己写的回调成功并正确执行了
-
- } else {
- // 代表用户已付款,但你自己写的回调执行失败(通常是因为你的回调代码有问题)
-
- }
- },
- /**
- * 日期格式化
- * @params {Date || Number} date 需要格式化的时间
- * timeFormat(new Date(),"yyyy-MM-dd hh:mm:ss");
- */
- timeFormat(time, fmt = 'yyyy-MM-dd hh:mm:ss', targetTimezone = 8){
- try {
- if (!time) {
- return "";
- }
- if (typeof time === "string" && !isNaN(time)) time = Number(time);
- // 其他更多是格式化有如下:
- // yyyy-MM-dd hh:mm:ss|yyyy年MM月dd日 hh时MM分等,可自定义组合
- let date;
- if (typeof time === "number") {
- if (time.toString().length == 10) time *= 1000;
- date = new Date(time);
- } else {
- date = time;
- }
-
- const dif = date.getTimezoneOffset();
- const timeDif = dif * 60 * 1000 + (targetTimezone * 60 * 60 * 1000);
- const east8time = date.getTime() + timeDif;
-
- date = new Date(east8time);
- let opt = {
- "M+": date.getMonth() + 1, //月份
- "d+": date.getDate(), //日
- "h+": date.getHours(), //小时
- "m+": date.getMinutes(), //分
- "s+": date.getSeconds(), //秒
- "q+": Math.floor((date.getMonth() + 3) / 3), //季度
- "S": date.getMilliseconds() //毫秒
- };
- if (/(y+)/.test(fmt)) {
- fmt = fmt.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length));
- }
- for (let k in opt) {
- if (new RegExp("(" + k + ")").test(fmt)) {
- fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (opt[k]) : (("00" + opt[k]).substr(("" + opt[k]).length)));
- }
- }
- return fmt;
- } catch (err) {
- // 若格式错误,则原值显示
- return time;
- }
- },
- },
- computed: {
- // 计算当前是否是ios app
- isIosAppCom(){
- let info = uni.getSystemInfoSync();
- return info.uniPlatform === 'app' && info.osName === 'ios' ? true : false;
- }
- },
- }
- </script>
- <style lang="scss" scoped>
- .app{
- padding: 30rpx;
- }
- input {
- border: 1px solid #f3f3f3;
- padding: 10rpx;
- width: 100%;
- box-sizing: border-box;
- height: 80rpx;
- }
- button {
- margin-top: 20rpx;
- }
-
- .label{
- margin: 10rpx 0;
- }
-
- .tips{
- margin-top: 20rpx;
- font-size: 24rpx;
- color: #565656;
- }
-
- .get-order-popup{
- background-color: #ffffff;
- padding: 30rpx;
- height: 60vh;
- border-radius: 30rpx 30rpx 0 0;
- overflow: hidden;
- }
- .mt20{
- margin-top: 20rpx;
- }
-
- .pd2030{
- padding: 20rpx 30rpx;
- }
-
- .table{
- font-size: 24rpx;
- }
- .align-left{
- text-align: left;
- width: 50%;
- }
- .align-right{
- text-align: right;
- width: 50%;
- }
-
-
- </style>
|