微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析


Posted in Javascript onAugust 16, 2019

前言

小程序支持webview以后,我们开发的好多h5页面,就可以直接在小程序里使用了,比如我们开发的微信商城,文章详情页,商品详情页,就可以开发一套,多处使用了。我们今天来讲一讲。在小程序的webview里实现微信支付功能。因为微信不允许在小程序的webview里直接调起微信支付。所以我们这节课就要涉及到小程序和webview的交互了。

老规矩先看效果。

因为这里涉及的东西比较多,录gif太多,没法上传,我就录制了一段视频出来。

https://v.qq.com/x/page/t0913iprnay.html

原理

先说下实现原理吧,实现原理就是我们在webview的h5页面里实现下单功能,然后点击支付按钮,我们点击支付按钮的时候会跳转到小程序页面,把订单号,订单总金额,传递到小程序里,然后小程序里使用订单号和订单金额去调起微信支付,实现付款,付款成功或者失败时都会有回调。我们再把对应的回调传递给webview,刷新webview里的订单和支付状态。

一,定义webview显示h5页面

关于webview的使用,我就不做讲解了,官方文档里写的很清楚,用起来也很简单。

https://developers.weixin.qq.com/miniprogram/dev/component/web-view.html

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

webview很简单,就是用一个webview组件,显示我们的网页。

二,定义h5页面

我这里启动一个本地服务器,用来展示一个简单的h5页面。

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

上图是我在浏览器里显示的效果。

接下来我们在小程序的webview里显示这个页面,也很简单,只需要把我们的src定义为我们的本地网页链接就可以了。

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

这里有一点需要注意

因为我们是本地链接,我们需要到开发者工具里把这一项给勾选。

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

三,来看下h5页面代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>小程序内嵌webview</title>
  <style>
    .btn {
      font-size: 70px;
      color: red;
    }
  </style>
</head>
<body>
<h1>我是webview里的h5页面</h1>
<a id="desc" class="btn" onclick="jumpPay()">点击支付</a>

<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js"></script>
<script>
  console.log(location.href);
  let payOk = getQueryVariable("payOk");
  console.log("payOk", payOk)
  if(payOk){//支付成功
    document.getElementById('desc').innerText="支持成功"
    document.getElementById('desc').style.color="green"
  }else{
    document.getElementById('desc').innerText="点击支付"
  }
  //获取url里携带的参数
  function getQueryVariable(variable) {
    var query = window.location.search.substring(1);
    var vars = query.split("&");
    for (var i = 0; i < vars.length; i++) {
      var pair = vars[i].split("=");
      if (pair[0] == variable) {
        return pair[1];
      }
    }
    return (false);
  }
  function jumpPay() {
    let orderId = Date.now();//这里用当前时间戳做订单号(后面使用你自己真实的订单号)
    let money = 1;//订单总金额(单位分)
    let payData = {orderId: orderId, money: money};

    let payDataStr = JSON.stringify(payData);//因为要吧参数传递给小程序,所以这里需要转为字符串
    const url = `../wePay/wePay?payDataStr=${payDataStr}`;
    wx.miniProgram.navigateTo({
      url: url
    });
    // console.log("点击了去支付", url)
    console.log("点击了去支付")
  }
</script>
</body>
</html>

h5代码这里不做具体讲解,只简单说下。我们就是在点击支付按钮时,用当前时间戳做为订单号(因为订单号要保证唯一),然后传一个订单金额(单位分),这里节约起见,就传1分钱吧,花的是自己的钱,心疼。。。。

关键点说一下

1, 必须引入jweixin,才可以实现h5跳转小程序。

<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js"></script>

2,跳转到小程序页面的方法

const url = `../wePay/wePay?payDataStr=${payDataStr}`;
wx.miniProgram.navigateTo({
   url: url
 });

这里要和你小程序的页面保持一致。payDataStr是我们携带的参数

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

四,小程序支付页

来看下我们的小程序支付页

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

小程序支付页功能很简单,就是来接收我们h5传过订单号和订单金额。然后去调起微信支付,实现支付。支付成功和支付失败都有对应的回调。

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

支付我们这里实用的小程序云开发来实现的支付,核心代码只有10行。由于支付不是本节的重点,所以这里不做具体讲解。感

兴趣的同学可以去看我写的文章和我录的视频

小程序支付文章:https://www.jianshu.com/p/2b391df055a9

小程序支付视频:https://edu.csdn.net/course/play/25701/310742

下面把小程序接收参数和支付的完整代码贴出来给大家

Page({
 //h5传过来的参数
 onLoad: function(options) {
  console.log("webview传过来的参数", options)
  //字符串转对象
  let payData = JSON.parse(options.payDataStr)
  console.log("orderId", payData.orderId)

  let that = this;
  wx.cloud.callFunction({
   name: "pay",
   data: {
    orderId: payData.orderId,
    money: payData.money
   },
   success(res) {
    console.log("获取成功", res)
    that.goPay(res.result);
   },
   fail(err) {
    console.log("获取失败", err)
   }
  })
 },

 //微信支付
 goPay(payData) {
  wx.requestPayment({
   timeStamp: payData.timeStamp,
   nonceStr: payData.nonceStr,
   package: payData.package,
   signType: 'MD5',
   paySign: payData.paySign,
   success(res) {
    console.log("支付成功", res)
    //你可以在这里支付成功以后,再跳会webview页,并把支付成功状态传回去
    wx.navigateTo({
     url: '../webview/webview?payOk=true',
    })
   },
   fail(res) {
    console.log("支付失败", res)
   }
  })
 }
})

代码里注释很清楚,这里有一点,就是我们支付成功后,需要告诉h5我们支付成功了,通知h5去刷新订单或者支付状态。

到这里我们就完整的实现了小程序webview展示h5页面,并且做到了h5和小程序的交互,实现了小程序webview的支付功能。
是不是很简单呢。

源码地址

https://github.com/qiushi123/xiaochengxu_demos

微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
SUN的《AJAX与J2EE》全文译了
Feb 23 Javascript
JavaScript操作XML 使用百度RSS作为新闻源示例
Feb 17 Javascript
jquery多行滚动/向左或向上滚动/响应鼠标实现思路及代码
Jan 23 Javascript
页面定时刷新(1秒刷新一次)
Nov 22 Javascript
JS+CSS实现模仿浏览器网页字符查找功能的方法
Feb 26 Javascript
Node.js 学习笔记之简介、安装及配置
Mar 03 Javascript
基于JavaScript实现下拉列表左右移动代码
Feb 07 Javascript
jquery dialog获取焦点的方法
Feb 09 Javascript
微信小程序 聊天室简单实现
Apr 19 Javascript
详解vue + vuex + directives实现权限按钮的思路
Oct 24 Javascript
vue-cli 2.*中导入公共less文件的方法步骤
Nov 22 Javascript
微信小程序实现多行文字滚动
Nov 18 Javascript
JS中的算法与数据结构之常见排序(Sort)算法详解
Aug 16 #Javascript
jQuery zTree插件使用简单教程
Aug 16 #jQuery
微信小程序 如何保持登录状态
Aug 16 #Javascript
JS事件流与事件处理程序实例分析
Aug 16 #Javascript
javascript事件监听与事件委托实例详解
Aug 16 #Javascript
使用Vue-Awesome-Swiper实现旋转叠加轮播效果&amp;平移轮播效果
Aug 16 #Javascript
详解Vue中组件传值的多重实现方式
Aug 16 #Javascript
You might like
phpmyadmin的#1251问题
2006/11/25 PHP
Linux Apache PHP Oracle 安装配置(具体操作步骤)
2013/06/17 PHP
你可能不知道PHP get_meta_tags()函数
2014/05/12 PHP
使用JS 清空File控件的路径值
2013/07/08 Javascript
js 得到文件后缀(通过正则实现)
2013/07/08 Javascript
使用javascript实现雪花飘落的效果
2015/01/13 Javascript
对JavaScript客户端应用编程的一些建议
2015/06/24 Javascript
jQuery实现表单步骤流程导航代码分享
2015/08/28 Javascript
javascript实现checkbox复选框实例代码
2016/01/10 Javascript
模拟javascript中的sort排序(简单实例)
2016/08/17 Javascript
基于jQuery实现的打字机效果
2017/01/16 Javascript
jQuery zTree树插件动态加载实例代码
2017/05/11 jQuery
深入浅出es6模板字符串
2017/08/26 Javascript
JS和JQuery实现雪花飘落效果
2017/11/30 jQuery
浅析JS抽象工厂模式
2017/12/14 Javascript
jQuery ajax仿Google自动提示SearchSuggess功能示例
2019/03/28 jQuery
vue中img src 动态加载本地json的图片路径写法
2019/04/25 Javascript
最简单的vue消息提示全局组件的方法
2019/06/16 Javascript
[01:39](回顾)各路豪强针锋相对,几经鏖战四强产生
2014/07/01 DOTA
Python中还原JavaScript的escape函数编码后字符串的方法
2014/08/22 Python
实例讲解Python设计模式编程之工厂方法模式的使用
2016/03/02 Python
Python更新数据库脚本两种方法及对比介绍
2017/07/27 Python
Python实现PS滤镜的旋转模糊功能示例
2018/01/20 Python
python 用下标截取字符串的实例
2018/12/25 Python
Python3直接爬取图片URL并保存示例
2019/12/18 Python
基于Python第三方插件实现西游记章节标注汉语拼音的方法
2020/05/22 Python
StubHub智利:购买和出售您的门票
2016/11/23 全球购物
香港时装购物网站:ZALORA香港
2017/04/23 全球购物
阿联酋电子产品购物网站:Menakart
2017/09/15 全球购物
英国鲜花速递:Serenata Flowers
2018/04/03 全球购物
应聘医学检验人员自荐信
2013/09/27 职场文书
文明礼貌演讲稿
2014/05/12 职场文书
党委书记个人检查对照材料思想汇报
2014/10/11 职场文书
购房委托书
2014/10/15 职场文书
2019通用版新员工入职培训方案!
2019/07/11 职场文书
详解JavaScript的计时器和按钮效果设置
2022/02/18 Javascript