2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

玩转社交裂变,携程小程序营销实现方案

  • 2020-02-15
  • 本文字数:2797 字

    阅读完需:约 9 分钟

玩转社交裂变,携程小程序营销实现方案

随着近两年小程序应用的普及,越来越多的商家通过小程序展开营销,相比 APP,小程序有更大机动性,能够支持搜索、会话、微信群、朋友圈等场景。


在跟随微信小程序的发展,一点一滴搭建起携程主小程序的过程中,携程市场部门也尝试了各式各样的营销裂变方案。通过活动、社群等方式引导用户进行分享传播,产生社交裂变,持续迭代新玩法,增加用户的活跃度和留存度,拉动活动 UV 日均几万至十多万不等,参与人数达数十万甚至百万。


这里跟大家聊聊我们尝试过的几个通用营销实现方案,实现方式不一而足,有更优的方案期待大家一起探讨。

一、海报绘制

目前小程序仅支持以卡片方式分享给好友或群,不能一键分享到朋友圈,基于二维码能够长按识别的特性,我们将二维码与分享内容相结合,以海报图的方进行分享与推广,通过关键信息的展示,使用户快速捕捉到商家传递的重点信息,进而扫一扫或长按识别进入小程序页面了解详情。



以微信小程序为例,官方已经提供了各类 cavas 绘图接口,包括文本、图片等,出于后续复用考虑,我们将其做了次简单封装,涵盖图片绘制剪裁、文字绘制、图片保存等。



在实际绘制时,首先定义一个 canvas 容器,然后根据海报图各元素宽高和定位,叠加背景底图、文字、二维码等信息,无需关注内部绘制方法。


let pic =new Picture('mycanvas', 375, 635)pic.getImgInfo(that.data.pic,function (data) {      //背景图      pic.drawImg(data.path, { left: 0, top: 0}, { width: 375, height: 635 })      //文字      pic.drawText(that.data.username, { size:13, color: '#fff', align: 'left' }, { left: 286, top: 505 })      pic.drawText(that.data.text, {size: 18,color: '#fff', align: 'left' }, { left: 80, top: 190 })       //绘制       pic.draw(function () {         pic.canvasToImgPath(function (path) {           that.setData({             img: path           })           that.uploadImg(path)         })       })})
复制代码


这里需要注意的是,绘制过程会涉及图片下载,在使用微信下载 API 时,需要在小程序后台将图片域名配置到 downloadFile 合法域名中,避免发布生产后,出现下载失败的情况,这个问题在开发工具或真机开启调试模式时不太会出现。


如果需要多行显示文字,并动态调整字体大小,则需要将文字进行拆行,切分为数组,


let that =thislettextLen = text.lengthlettopHeight = textLen < 6 ? 190 : 180letfontBigger = true //是否有一行字数大于14个for (let i= 0; i < textLen; i++) {  if (text[i].length > 13) {    fontBigger = false    break  }}for (let i= 0; i < textLen; i++) {  if (textLen < 6 && fontBigger) {    pic.drawText(text[i], { size: 18, color:'#' + that.data.fontcolor, align: 'left' }, { left: 80, top: topHeight })    topHeight = topHeight + 35  } else {    pic.drawText(text[i], { size: 15, color:'#' + that.data.fontcolor, align: 'left' }, { left: 80, top: topHeight })    topHeight = topHeight + 27  }}
复制代码

二、搜索直达

微信搜一搜入口的开放拉近了商家与用户的距离,用户在搜一搜输入关键词,页面会呈现相关服务的小程序推荐卡片,点击搜索结果即可直达小程序内业务页面。



搜一搜大致流程是:


1)微信将搜索请求包通过 http post 方式发送至开发者在 mp 平台上配置的消息推送 URL


2)开发者收到请求之后进行签名验证和解密,并解析意图场景


3)根据意图场景将消息分发给各业务方查询服务,并将返回的 widgetData 加密返回微信


4)客户端将卡片数据 push 到小程序 widget 中进行展示



时序图引用自微信官方文档


其中,客户端初始渲染 widgetData 方式可以参考下面这段示例,微信传入的 query 包含三个字段widgetDatawxOpenIdwxParamData,而我们需要的数据是从widgetData获取,意图场景type值则可以通过wxParamData获取。


const ctx= this.getContext()      const {            width,            height      } = options
//获取 [用户搜索意图数据] 和 [卡片数据] let wxQuery = options.query
gWidgetData=this.getWidgetParam('widgetData', wxQuery) || {}gQueryData= this.getWidgetParam('wxParamData', wxQuery)
//获取业务类型if(gQueryData) {bizType =gQueryData.type || ''}
//绘制widgetWidgetDom.init({windowWidth:width,windowHeight:height,classObj,ctx});
//设置widget模板this.setWidgetRender()
//渲染widget数据this.setWidgetData()
//设置卡片自适应高度 WidgetDom.useDynamicHeight()
复制代码


继首次渲染后,客户端会以一定的时间间隔,不断轮循请求微信后台,拿到最新数据以 push 到小程序 widget 中进行更新。


onDataPush(options){//获取widget数据    gWidgetData = this.getWidgetParam('data',options);
//卡片数据为空,不做渲染 if (!gWidgetData) { return }
//重新设置widget模板 this.setWidgetRender()
//重新渲染widget数据 this.setWidgetData() }
复制代码

三、一码多用

二维码作为小程序的重要流量入口之一,能够快速吸引流量和转化,是打通线上线下场景的重要方式。而随着小程序平台的多样化,微信、支付宝、百度等都有自家一套二维码生成接口,仅微信而言,就区分 A/B/C 三种码以应用于不同场景,对于同一个活动页面多端推广和二维码管理来说都相当不方便。


幸运的是,部分小程序已经支持了对普通链接二维码的小程序跳转兼容,这种兼容的初衷是支持原有已投放的 H5 链接二维码能够继续使用下去,不用单独切换成小程序码。因此我们尝试使用一个通用 H5 链接二维码,根据扫码工具的区分,完成不同小程序的跳转。


首先,按照微信要求在小程序管理后台配置跳转小程序的二维码规则,将 h5 页面规则映射至小程序统一的扫码处理中间页;然后分别准备好 H5 和小程序两侧的中间页,H5 中间(即普通二维码的路径)负责标记页面 ID,小程序中间页负责提取路径中传递过来的 q 参数。


假设用户使用微信扫码,那么微信将匹配出规则并拉起自身小程序,进入中间页,在此页面向服务端换取线下配置的目标页地址,最终完成扫码跳转流程,同理,使用百度或支付宝小程序扫码,将会拉起各自平台小程序,若无法识别,将进入 H5 保底页面。


四、总结

通过小程序来裂变有两大特点,拉新成本低和高转化率。而得益于小程序“无需安装、触手可及、用完即走、无须卸载”的优势,用户参与起来门槛较低,不需要下载或关注,只要点开小程序,就可以使用,这在很大程度上减少了因为需要下载或关注而所流失的用户。在此基础上,配合二维码、海报图等便捷推广方式,只需要点击转发给好友/群或朋友圈即可达到快速裂变效果。


作者介绍


王红,携程市场部前端工程师,目前主要负责市场公众平台相关工作。


本文转载自公众号携程技术(ID:ctriptech)。


原文链接


https://mp.weixin.qq.com/s/TvNDuSryt9SmjYVOvGx0LA


2020-02-15 17:381891

评论

发布
暂无评论
发现更多内容

Amazon Generative AI Use Cases:“开箱即用的企业级生成式AI应用平台”

亚马逊云科技 (Amazon Web Services)

指标混乱终结者:ChatBI怎样让全公司说同一种“数据语言”?

飞鲤

数据分析 ChatBI Data+AI

7个核心功能让你更好地使用YashanDB数据库

数据库砖家

穿越钱塘江:一条高铁隧道背后的技术挑战

DevOps和数字孪生

轨道交通

重新定义网络安全职业:从"解决问题"的角度出发

qife122

网络安全 问题解决

有哪些可离线使用的白板软件?6个主流的白板工具汇总

职场工具箱

人工智能 效率工具 在线白板 办公软件 AIGC

展览馆LED屏幕:让展示更有“光”

Dylan

视觉 LED LED display 展览 LED屏幕

哈尔滨等保测评:测评后的持续安全管理

等保测评

实测谷歌Veo 3.1视频模型!附零门槛免费使用攻略和提示词

阿星AI工作室

产品 AI 产品经理 大模型 AI视频

海外社交媒体监测工具全攻略:功能、价格与选型指南

沃观Wovision

社交媒体 沃观Wovision 舆情监测系统 海外舆情监测

7个关键技巧提升YashanDB数据库的性能

数据库砖家

哈尔滨等保测评:筑牢数字时代安全防线

等保测评

哈尔滨等保测评:常见问题与应对之道

等保测评

7个方法优化YashanDB数据库的存储性能

数据库砖家

7个关键步骤让您充分利用YashanDB生态系统

数据库砖家

7个因素影响YashanDB数据库的性能优化

数据库砖家

传帮带 人才梯队建设经验总结(13)

万里无云万里天

人才培养 工业 工厂运维

OPPO智慧服务吹起AI之风,移动开发拨云见日

脑极体

AI

谷歌推出全新语音搜索技术 S2R:跳过语音转文字,直接理解语音意图;代体 AI 推出端侧语音输入法丨日报

RTE开发者社区

7个实用技巧提高YashanDB数据库的安全性

数据库砖家

大数据-126 - Flink一文搞懂有状态计算:State Backend 工作原理与性能差异详解 核心原理与作用

武子康

Java 大数据 flink spark 分布式

智源“透明心脏”:全自动3D心肌瘢痕重建,让三维诊断走进中国日常临床

智源研究院

人工智能 AI医疗

从0到1掌握京东API:商品详情获取技巧与避坑指南

Datafox(数据狐)

京东商品详情接口 京东商品数据采集 京东商品详情API 京东数据采集 京东商品数据分析

7个关键点了解YashanDB的最佳实施策略

数据库砖家

手撕大模型 | MQA 和 GQA 原理解析

地平线开发者

自动驾驶; 算法工具链 地平线征程6

Python 3.14发布:多解释器让性能飙升300%,GIL时代即将终结!

程序员晚枫

Python

Python版本进化史:从3.6到3.14,每个版本都带来了什么惊喜?

程序员晚枫

Python

为什么你的体育App总被卸载?可能不是你的错

ggscoreLynne

利用Next.js中间件漏洞实现SSRF攻击与RCE

qife122

SSRF 漏洞挖掘

鸿蒙应用开发从入门到实战(二十三):一文搞懂ArkUI弹性布局

程序员潘Sir

鸿蒙 HarmonyOS

玩转社交裂变,携程小程序营销实现方案_技术管理_王红_InfoQ精选文章