小程序之社交

主要内容:

  1. 小程序调用App
  2. App调用小程序
  3. App分享小程序
  4. 小程序自身分享功能
  5. 小程序与H5交互
  6. 小程序之间互相跳转
  7. 绘制小程序分享图片

小程序与App之间的互相调用

小程序调用App

官方文档: https://developers.weixin.qq.com/miniprogram/dev/api/launchApp.html

只有在特定条件下,小程序才具有打开app的能力,小程序内部管理了一个打开APP能力的状态,为true可以打开,为false则不可以打开。


image.png

操作步骤:

  1. 需要为小程序的<button>组件的open-type设置为“launchApp”
  2. app端需要接入OpenSDK

iOS 参考文档 https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=1417694084&token=&lang=zh_CN

Android 参考文档 https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=1417751808&token=&lang=zh_CN

  1. Android第三方app需要处理ShowMessageFromWX.req的微信回调,iOS则需要将appid添加到第三方app工程所述的plist文件URL types字段。
    app-parameter的获取方法请参考 Android SDKSample 中 WXEntryActivity 中的 onResp 方法以及 iOS SDKSample 中 WXApiDelegate 中的 onResp 方法
<button open-type="launchApp" app-parameter="wechat" binderror="launchAppError">打开App</button>

Page({
  launchAppError: function(e){
    console.log(e.detail.errMsg);
  }
})

App调用小程序

官方文档地址:App唤醒小程序
ios文档地址:iOS唤醒小程序

操作步骤

  1. 下载Android开发工具包:资源中心 -> 开发资源 -> 资源下载 -> Android资源下载
  2. 调用接口WXLaunchMiniProgram
String appId = "wxd930ea5d5a258f4f"; // 填应用AppId
IWXAPI api = WXAPIFactory.createWXAPI(context, appId);

WXLaunchMiniProgram.Req req = new WXLaunchMiniProgram.Req();
req.userName = "gh_d43f693ca31f"; // 填小程序原始id
req.path = path;                  //拉起小程序页面的可带参路径,不填默认拉起小程序首页
req.miniprogramType = WXLaunchMiniProgram.Req.MINIPTOGRAM_TYPE_RELEASE;// 可选打开 开发版,体验版和正式版
api.sendReq(req);

回调说明
WXEntryActivity中

public void onResp(BaseResp resp) {
    if (resp.getType() == ConstantsAPI.COMMAND_LAUNCH_WX_MINIPROGRAM) {
        WXLaunchMiniProgram.Resp launchMiniProResp = (WXLaunchMiniProgram.Resp) resp;
        String extraData =launchMiniProResp.extMsg; //对应小程序组件 <button open-type="launchApp"> 中的 app-parameter 属性
    }
}

App分享小程序

注意:如果微信版本低于6.5.6的话,那么小程序类型的分享将自动转换成网页类型分享。所以必须填写网页链接字段,确保低版本客户端能打开网页链接

要求

  1. 发起分享的App与小程序属于同一微信开放平台账号
  2. 支持分享小程序类型消息至会话,暂不支持到朋友圈
  3. 支持分享开发版 / 体验版小程序
WXMiniProgramObject miniProgramObj = new WXMiniProgramObject();
miniProgramObj.webpageUrl = "http://www.qq.com"; // 兼容低版本的网页链接
miniProgramObj.miniprogramType = WXMiniProgramObject.MINIPTOGRAM_TYPE_RELEASE;// 正式版:0,测试版:1,体验版:2
miniProgramObj.userName = "gh_d43f693ca31f";     // 小程序原始id
miniProgramObj.path = "/pages/media";            //小程序页面路径
WXMediaMessage msg = new WXMediaMessage(miniProgramObj);
msg.title = "小程序消息Title";                    // 小程序消息title
msg.description = "小程序消息Desc";               // 小程序消息desc
msg.thumbData = getThumb();                      // 小程序消息封面图片,小于128k

SendMessageToWX.Req req = new SendMessageToWX.Req();
req.transaction = buildTransaction("webpage");
req.message = msg;
req.scene = SendMessageToWX.Req.WXSceneSession;  // 目前支持会话
api.sendReq(req);

小程序自身分享功能

分享给好友
注意:

  1. 如果想在页面内发起转发,只能通过button组件设置属性open-type="share",更多请参考官方转发api
Page({
  onShareAppMessage: function (res) {
    // 区分页面右上角分享和页面内 button 点击
    if (res.from === 'button') {
      // 来自页面内 button 转发按钮
      console.log(res.target)
    }
    return {
      title: '送给你一个大红包', // 分享文案
      path: '/page/news/index', // 分享页面路径
      imageUrl: 'https://***.zhaoshanshan.com/***.png' // 分享图片,当不传入时,默认使用截图,图片长宽比为5:4
    }
  }
})...

获取群标识

当需要分享到多个群,而统计群个数的时候,通过wx.getShareInfo(OBJECT)方法获取,需要传入shareTicket。

  1. 传入shareTicket
onLoad: function (options) {
    // 定义携带 shareTicket 的转发
    wx.showShareMenu({ withShareTicket: true })
    ...
  },
  1. 分享时获取shareTicket
  2. 根据shareTicket获取群标识
onShareAppMessage: function (res) {
    let that = this
    return {
      title: '送你一个大红包!',
      path: `/pages/news/index`,
      imageUrl: '***',
      success: function (res) {
        // 获取 shareTicket
        var shareTickets = res.shareTickets
        if (shareTickets && shareTickets.length !== 0) {
          wx.getShareInfo({
            shareTicket: shareTickets[0],
            success: function(res) {
              console.log('加密之后的群标识:', res.iv)
            })
          }
        }
      }
    }
 }

发送模板消息

小程序定义模板消息地址:https://mp.weixin.qq.com/wxopen/tmplmsg?action=public_list&token=826838731&lang=zh_CN
模板消息的触发条件有两个:

  1. 支付
  2. 提交表单

操作步骤:

<form report-submit="true" bindsubmit="shareBtnTap">
  <button formType="submit" open-type="share">发红包</button>
</form>

Page({
  shareBtnTap (e) {
    // 获取formId
    console.log('用于发送模版消息的formId: ', e.detail.formId)
  },
})

调用接口下发末模板消息

{
  "touser": "OPENID",  // 接收用户的openid
  "template_id": "TEMPLATE_ID",  // 模版id
  "page": "index",  // 用户点击后的跳转页面
  "form_id": "FORMID",
  "data": {
      "keyword1": {
          "value": "哈哈哈"
      },
      "keyword2": {
          "value": "哈哈哈哈"
      },
      "keyword3": {
          "value": "哈哈哈哈"
      } ,
      "keyword4": {
          "value": "H哈哈哈哈"
      }
  },
  "emphasis_keyword": "keyword1.DATA"  // 模板需要放大的关键词,不填则默认无放大
}

分享到朋友圈

官方获取二维码地址
微信小程序是没有提供分享到朋友圈的API的,只能引导用户将小程序码保存到本地,再自行分享到朋友圈。
微信提供了三种生成二维码的接口:

image.png

  1. A接口和B接口生成的二维码数量有限
  2. B接口更适合携带不同query,更适合运营需要

B接口示例

{
  scene: 'user_123:token_123',  // 参数
  page: 'pages/news/index',  // 跳转页面
  width: 430  // 二维码宽度
}

这样当用户扫完二维码时会跳转到pages/news/index页面
接着在pages/news/index页面中处理参数:

Page({
  onLoad (option = {}) {
    console.log('小程序码上携带参数scene ', option.scene)
    // 处理scene
    this.sceneControl(option.scene)
  }
})
  1. 下载二维码图片到本地
wx.downloadFile({
  url: 'https://***.zhaoshanshan.com/***/***.png', // 一定要有文件后缀
  success: function(res) {
    if (res.statusCode === 200) {
      console.log('临时图片路径: ', res.tempFilePath)
    }
  }
})
  1. 根据图片临时路径,将其保存到手机相册
wx.saveImageToPhotosAlbum({
  filePath: this.data.filePath,
  success: function (res) {
    wx.showModal({
      title: '已保存到相册',
      content: '请自行分享到朋友圈,分享好友,领红包',
      showCancel: false,
      confirmText: '确定',
      success: function(res) {
        if (res.confirm) {
          // 返回上一页
          wx.navigateBack()
        }
      }
    })
  },
  fail: function (res) {
    wx.showModal({
      title: '下载失败',
      content: '未获得访问相册权限,请尝试截取屏幕分享至朋友圈。',
      showCancel: false,
      confirmText: '确定',
      success: function(res) {
        if (res.confirm) {
          // 返回上一页
          wx.navigateBack()
        }
      }
    })
  }
})

小程序与H5交互

小程序载入H5

  1. 使用web-view组件,其加载的url需要配置到域名白名单中,在微信公众平台设置-> 开发设置 -> 业务域名下进行设置

一般情况下,需要对载入的url进行转义:
<view>
<web-view src="{{u}}"></web-view>
</view>

decodeURIComponent(option.u)
  1. 有时候需要在url后面追加一些信息,使用fixWebLinkURL对信息进行转换
const u = fixWebLinkURL(decodeURIComponent(option.u))

function fixWebLinkURL(url) {
  // 把 hash 放在最后面
  let qs = `********`
  let match = url.split('#')
  if (match[1]) {
    qs += '#' + match[1]
    url = match[0]
  }
  return ~url.indexOf('?') ? `${url}&${qs}` : `${url}?${qs}`
}

H5调用小程序

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

//方式一
function ready() {
  console.log(window.__wxjs_environment === 'miniprogram') // true
}
if (!window.WeixinJSBridge || !WeixinJSBridge.invoke) {
  document.addEventListener('WeixinJSBridgeReady', ready, false)
} else {
  ready()
}

//方式二
wx.miniProgram.getEnv(function(res) {
  console.log(res.miniprogram) // true
})
  1. 执行跳转
wx.miniProgram.navigateTo({url: '/path/to/page'})
  1. 向小程序发送消息
<web-view src="{{url}}" bindmessage="handleMsg"/>
Page({
  handleMsg: function (e) {
    console.log('h5 postMessage is', e.detail.data)
  }
})

h5触发事件

wx.miniProgram.postMessage({ data: '这是一条传递给小程序的消息' })

小程序之间互相跳转

只有同一公众号之下关联的小程序才能互相跳转

<view class="btn-area">
  <navigator url="/page/navigate/navigate?title=navigate" hover-class="navigator-hover">跳转到新页面</navigator>
  <navigator url="../../redirect/redirect/redirect?title=redirect" open-type="redirect" hover-class="other-navigator-hover">在当前页打开</navigator>
  <navigator url="/page/index/index" open-type="switchTab" hover-class="other-navigator-hover">切换 Tab</navigator>
  <navigator target="miniProgram" open-type="navigate" app-id="" path="" extra-data="" version="release">打开绑定的小程序</navigator>
</view>

//该接口即将废弃,使用如上navigator组件来实现该功能
wx.navigateToMiniProgram({
  appId: '',
  path: '',
  extraData: {
    // 传递的参数
  },
  envVersion: 'develop', // 要打开的小程序版本 develop  trial  release
  success(res) {
    // 打开成功
  }
})

wx.navigateBackMiniProgram()方法用于返回到上一个小程序。更多文档请参考wx.navigateBackMiniProgram · 小程序

绘制小程序分享图片


参考文章:https://www.jianshu.com/p/ceb42fe76e77

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,460评论 25 707
  • 一直想写一篇年终总结,码码字,从我的视角出发,没想到竟给忘了,不该,不该。 其中很多思想来自他人,万望勿吐槽...
    墨染书阅读 236评论 0 0
  • 凭楼椅栏望外,数岁不知。牡丹以凋随风去,今夕是何夕? 拂袖拭泪思君,暮日晨昏。梧桐琴起曲幽幽,今愿君当归。
    朱砂赋难忆阅读 111评论 0 0
  • 世人的想法的笼统的分两种,一种是命定论,一种是创造论。 命定论的人,认为一切都是上天在安排,自己随遇而安,以一种被...
    纵深解析阅读 242评论 0 0
  • 其实很早就注意到这样的一个问题,单纯从自己的感受并没有相关调查数据论证。其实重点大学里我们从家庭条件方面去分类学生...
    二次风阅读 207评论 0 1