前端技术专家/ 腾讯云最具价值专家(TVP)
随着微信小程序不断发展壮大,传统的 CRM 厂商也在不断向微信上迁移,毕竟微信的背后是巨大的用户和流量,还有极其方便的移动支付渠道。用微信小程序来做CRM,和以前的做法存在一些比较明显的差异,主要包括这几个方面:用户的使用习惯不同、技术上的实现方式不同、运营方面的做法不同。所以,业内给这一类的 CRM 应用起了个新名字,叫做 Social CRM,简称 SCRM。本主题将会为您讲解:1、SCRM 在商业层面如何理解,为什么目前会变得流行起来?2、当前市面上 SCRM 的发展状况如何?3、SCRM 类应用有哪些通用的业务场景和组件?4、SCRM 在技术上具体怎么实现?5、最后,带你上手实际写一个 SCRM 小程序,完整覆盖小程序+云开发的完整流程。
随着微信小程序不断发展壮大,传统的 CRM 厂商也在不断向微信上迁移,毕竟微信的背后是巨大的用户和流量,还有极其方便的移动支付渠道。用微信小程序来做CRM,和以前的做法存在一些比较明显的差异,主要包括这几个方面:用户的使用习惯不同、技术上的实现方式不同、运营方面的做法不同,所以,业内给这一类的 CRM 应用起了个新名字,叫做 Social CRM,简称 SCRM。
本期腾讯产业互联网学堂大咖分享邀请大漠穷秋 老师,将会为大家介绍基于微信小程序的SCRM,带大家深入理解SCRM的发展和应用场景,并进行社交化客户管理小程序的实战教学,上手实际写一个 SCRM 小程序,完整覆盖小程序+云开发的完整流程。
本次分享内容:
1、概要介绍小程序云开发
2、SCRM的商业理解
3、界面设计-定义产品功能
4、云端-定义数据结构和云函数
5、开始写代码实现界面和功能
小程序云开发是经典的serverless的实现,小程序端提供了完善的组件库和开发工具,开发者可以聚焦自己的业务实现。云端提供了基于MongoDB的数据库、对象存储和云函数,以及运维工具等功能。这样一来,整个开发、部署、运维就可以全部一站式完成,借助于微信和腾讯云强大的功能帮我们节省了大量的时间,节省了大量的钱,这就是它的本质。云端有运营分析的界面,当一款小程序上线之后就可以在运营分析界面上看到用户量和资源使用的情况,包括监控的图表都可以看到。
小程序云开发能力简介
如何使用云开发
首先在开发工具中新建项目时选择后端服务为小程序云开发,即可快速生成云开发的项目模板,在界面的左上角点击云开发按钮,就可直接调转到环境创建的界面,添加环境名称,等待部署完成后就可以在开发工具中调用云开发。
小程序云开发的无服务开发模式,助力快速上线小程序。对比传统开发和云开发模式,传统开发模式下需要考虑弹性伸缩、异地容灾、网络防护等,还需完成自己的业务逻辑,而在云开发模式下,这些需要考虑的东西通通由腾讯云基础服务处理了,开发者只需要考虑自己的业务逻辑,大大降低了工作量。
这款小程序的名字是“客流”,本质上就是SCRM(Social CRM)。
我们先理解一下什么是SCRM?大家已经比较了解CRM系统的概念和背景,截一张Wikipedia上面的完整定义给大家看一下:
CRM系统在传统企业里面用的非常多,比如:电商、金融、餐饮、教育、电信、医疗……。所有巨头企业都有自己定制版的CRM系统,因为他们客户量非常大。比如说典型的电信业,像中国移动、中国联通他们全国都有几个亿客户,这些客户的资料,客户的关系都需要大型的CRM系统进行维护。
CRM是一个很大的概念,这种系统一般会有很多功能,比如说sales、marketing、customer、employee support等等,下面是大概的结构图。
有人会问,既然我们在桌面端已经有了这么庞大的CRM系统,为什么现在要向微信小程序上做迁移呢?典型的几个原因如下:
所有的传统的巨头他们都会开发自己专用的CRM系统,他们会投入大量的金钱和人力。比如说电力、电信、金融、交通这些领域,不管是国内还是国外,都是这样的。
但是,除了这些巨头之外,我们日常生活里面很多的小生意,做小生意的小老板、小店也需要维护自己的客户关系,比方说:
很明显,这些小生意,小老板不可能自己开发小程序,也不可能招几个程序员投十万二十万来开发一个CRM系统,这是不可能的。那么,这些小店、小老板是怎么维护自己的客户关系的呢?看下图,所以在这种场景之下,SCRM的概念就变得更加重要,我们需要更加普惠的SaaS实现,让海量的做小生意的老板也能维护、管理自己的客户关系。同时,我们还可以让这些小老板可以借助微信庞大的社交关系来进行营销,从而提升自己的营业额。
但是,SCRM小程序跟传统的CRM系统还是有很大区别的:
目前市面上还有一些同类产品,我们来做一下简单的对比。比如说微信的企业版、还有钉钉,他们也在推SCRM的功能。但是,我们在微信上用小程序来实现SCRM会更加轻、更加薄,传播性更好,跟用户也更贴近。我们不需要让用户安装独立的APP,打开微信就可以直接使用。
用草图绘制工具来画一下小程序需要实现的功能,首页要放一个名片告诉大家我是谁,我有什么店,我的联系方式是什么。详情页上面放一些图文介绍,甚至放一些视频,用来告诉别人我有一些什么样的产品和服务,它们是什么样子。
还有基本的客户关系的维护、沟通交流的渠道,比如说可以跟客户发消息、打电话等等场景。同时还可以有一些图表统计界面,告诉我现在有多少客户,我和客户之间的关系是一种什么样的结构。下面这些是设计草图,我们没有办法拿到很详细地人际关系链,人际关系链是微信的核心资产,我们最多拿到一些子图(Subgraph)。大概一共有30个页面需要实现,得到界面之后就可以来定义云端的数据结构和云函数了。
在微信开发者工具里面点云开发按钮就可以打开云开发相关的界面,我们在数据库页面上可以定义数据结构。
小程序的数据库背后实际上是MongoDB,“客流”这个小程序一共定义了7个集合,集合的概念类似于关系性数据库里的一张表,我们所有的数据都放在不同的集合里。
但是,NoSQL里面的集合跟传统关系型数据库有很多不一样的地方。除了刚才有人问的事务问题之外,实际开发过程中还有一些比较麻烦的地方。比如,多个集合的关联查询写起来比较恶心,没有传统的SQL语句那么方便。
对象存储这块可以建立不同的目录,用来放不同的上传文件,根据不同的业务模块建一些文件夹,把同一个业务模块相关的文件都放在对应的目录里面。
云函数用来定义云端调用的方法,提供了定时器之类的工具函数。我们可以利用云函数来实现很多业务功能,比如说定时把数据库里面某些用来做统计的集合生成数据。
我们一共定义了7个集合,分别解释如下:
首先注册号云开发appid,如果注册好了就跟着我一起尝试做一个界面出来,如果还没有的话就听我解释代码里面比较关键的点。
开发过程中有坑的话,我会把一些坑解释一下,实际上我踩了很多坑。
小程序起名字是有讲究的,有自动校验的,比如说你起一个很奇怪的名字或者上传很奇怪的logo是肯定审核不通过,所以要预先准备好。
走完注册过程之后会拿到一个很关键的较appid,它是唯一的,有了appid之后就可以创建小程序了。
创建完之后会自动生成一个默认的界面,还会生成一些代码,这些都是默认的,你在开发的时候肯定是要把它删掉的,删掉之后会得到一个比较干净的项目结构。
你不一定要在微信开发者工具里写代码,因为这个开发者工具虽然集成了很多功能,部署、版本管理都可以在这里面完成,但是写代码的能力实在太差了。比如说没有智能提示,然后也没有插件。所以,推荐大家还是用VS Code去写代码,在VS Code里面打开小程序项目的根目录就可以了。
WeUI提供哪些功能?
你可以访问一下他们的官方网站,里面有一个体验版的小程序可以扫描看一下。它把基础的表单、导航条、基础的grid都提供给你了,这些代码可以直接抄过去使用,不用自己写这些结构。另外,它还定义了层级规范,告诉你应该怎么组织界面的层次结构,这些都是很好的功能。
除了WeUI之外,在小程序文档上面还可以找到内置的组件。小程序内置了很多内部的组件,比如说图表、文本,这是已有的组件库。
我们在全局的app.wxss里面引入WeUI相关的样式。这些样式文件的后缀都是wxss,实际上是CSS的子集,并不能支持所有的CSS规范。大家注意wxml和wxss虽然他们都支持基本的HTML和CSS的语法,但并不是全集,所以在写的时候还是有一些坑的,要特别翻阅一下官方的文档。
接下来给大家看最终完成的代码,我提交了两份,在github和gitee上面都提了一份,我把路径发给你们,如果有兴趣可以自己下载下来继续研究。
注意,千万不要用我的appid。
云端的数据结构也给你们,这样你们就可以在本地把项目创建起来了。
这个小程序的主体框架已经都实现了,总共有31个界面,总共花了4个完整的工作日,后面我找时间把它全部做好然后上线。