小程序开发十问

作者: 极乐叔 | 来源:发表于2018-05-14 10:52 被阅读11次

A 跳转到 B 时,可以通过 url 中 query 传递数据。

B 页面 onLoad(options) 方法中的 options 会包含 query 中的 key-value 的内容。

如果需要传递如 json 或数组这样的结构化数据,我们也可以先把结构化数据做 string 化后再 encode 一下后,再通过该方式传递。

encodeURIComponent(JSON.stringify(xxx))

在 B 页面中,获得内容后,通过以下方法,解析出数据。

JSON.parse(decodeURIComponent(xxx))

第二问:页面间如何回传数据?

比如 A 打开了 B,B 中一些数据需要传送到 A。可以先获取前一个页面实例,然后直接调用前一个页面数据进行数据传输。

const pages = getCurrentPages();
const prevPage = pages[pages.length - 2];
prevPage.methodOfPrevPage(data);

第三问:小程序如何与服务端保持会话?

因小程序框架并无 Cookie 管理机制,并且小程序也未提供向 WebView 设置 Cookie 的方法。所以如果我们想继续使用 Session-Cookie 机制,则需要自己实现一套,我们可以简单的提取出 set-cookie 头中有效的 cookie 内容,然后存储在内存和本地中,再下一次请求的时候,把这些 cookie 组装起来使用。当涉及到 WebView 时,我们可以通过 query 的方法,把这些 Cookie 内容传给 Web 端,用来维持和服务端的有效会话。

当然你也可以采用 Token 机制,与服务端保持会话。

第四问:如何调用子组件中的方法?

我们可以在自定义组件中加上一个 id,然后在 js 代码中使用如下方法:

this.selectComponent('#id').methodOfComponent(data);

第五问:子组件中如何调用父组件的方法?

使用组件事件方法,详细文档: developers.weixin.qq.com/miniprogram…

在父组件中使用子组件时,可以定义一个

bind:customMethod='parentMethod'

然后子组件中,可以使用以下代码调用父类的方法

this.triggerEvent('customMethod', data);

第六问:小程序如何进行数据分析?

小程序后台提供了数据分析能力,具体可见: developers.weixin.qq.com/miniprogram…

并且如果需要把数据接入到自己的服务中,也可以通过调用微信接口的方式拿到数据: developers.weixin.qq.com/miniprogram…

如果需要自定义数据,我们可以在小程序中调用方法:

wx.reportAnalytics(eventName, data)

不过在使用前,需要在小程序管理后台自定义分析中新建事件,配置好事件名与字段。另外自定义事件的数据无法通过接口获得,

所以如果你需要在自己的服务器上也分享自定义事件,那只能自己开发几个接口了。

第七问:微信小程序的二维码生成有次数限制吗?

微信提供了三种方式生成微信二维码,详情可查看: developers.weixin.qq.com/miniprogram…

此三种类型二维码都需要服务端端通过 access_token 调用微信接口生成。并且仅能生成已发布的小程序的二维码,所以你的小程序先得上线后才能测试该功能。有点坑。

其中接口A、和接口C有次数限制,接口A加上接口C,总共生成的码数量限制为100,000。

接口 B 次数无限制,但调用频率有限制,5000次/分钟。

接口 A 和接口 C 相对接口 C 可以传入一个最大长度不超过 128 字节的 path,你可以在 path 中通过 query 的形式传入参数。

接口 B 相对 A、C,把 PATH 拆成了,page 和 scene,其中 scene 最大为 32 个字符。可以在 page 的 onLoad 方法中通过 options.scene 方式获得这个 scene。

第八问:普通二维码可以打开小程序吗?

可以,需要在小程序管理后台添加,添加后,即可扫描以下内容的二维码就可跳转到小程序的指定页面了。

详情可查看: developers.weixin.qq.com/miniprogram…

<figure style="margin: 24px 0px; color: rgb(26, 26, 26); font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "PingFang SC", "Microsoft YaHei", "Source Han Sans SC", "Noto Sans CJK SC", "WenQuanYi Micro Hei", sans-serif; font-size: 16px; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; white-space: pre-wrap; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255);"> image

</figure>

第九问:小程序版本的兼容情况如何?

小程序运行在微信上,并且小程序的基础库随微信版本而发版。所以不同的微信版本会对小程序的表现有所影响。 有关各个版本的基础库的覆盖率可以查看以下链接。 developers.weixin.qq.com/miniprogram…

目前微信推荐的最低基础库版本,可以覆盖 80% 以上的微信用户。另外低版本的微信在使用使用高基础库版本的小程序会提示升级微信。

第十问:小程序代码可以运行在浏览器中吗?

小程序使用的是自己的一套框架,只是借用了目前主流的 html + js + css 的开发形式,所以小程序代码本身是无法直接运行在浏览器中的。

目前美团开源了一套自己的方案: github.com/Meituan-Dia… ,使用 vue 的形式来编写小程序。并且可以通过改变打包配置的方式,让同一套代码可以同时运行在小程序和浏览器中。

最近在公司做了几款小程序,对小程序开发有了一些经验,如果你对小程序开发有更多疑问,可以通过 微博:彭涛me 或 Github: CPPAlien 联系到我,我们可以一同交流学习。

作者:CPPAlien
链接:小程序开发十问-教程-小程序社区-微信小程序-微信小程序开发社区-小程序开发论坛-微信小程序联盟
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关文章

  • 小程序开发十问

    第一问:小程序页面间如何传递数据? A 跳转到 B 时,可以通过 url 中 query 传递数据。 B 页面 o...

  • 小程序开发十问

    A 跳转到 B 时,可以通过 url 中 query 传递数据。 B 页面 onLoad(options) 方法中...

  • 潍坊小程序开发

    潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍...

  • 潍坊商城小程序开发制作

    潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍坊小程序开发潍...

  • 如何开发商城小程序

    经常微信上朋友在问,微信小程序如何开发?目前来说,微信小程序用于电商的比较多,那么电商小程序如何开发呢? 一、了解...

  • 潍坊商城小程序网站开发制作

    潍坊商城小程序开发制作潍坊商城小程序开发制作潍坊商城小程序开发制作潍坊商城小程序开发制作潍坊商城小程序开发制作潍坊...

  • 怎么筛选小程序开发公司

    微信小程序推出之后,市场上的微信小程序开发公司也纷纷跟进。那么很多客户都会问∶哪个是好的微信小程序开发公司? 如何...

  • 2018-04-26

    湘潭企客猫微信小程序开发报价,湘潭微信小程序开发多少钱 微信小程序为何能立于不败之地? 很多人问:为什么微信的小程...

  • 小程序Cloud开发归纳

    小程序云开发 小程序·云开发是微信团队联合腾讯云推出的专业的小程序开发服务。开发者可以使用云开发快速开发小程序、小...

  • 小程序如何去运营、推广

    最近很多做了小程序开发或在考虑做小程序的客户都在问如何去推广运营自己的小程序呢? 首先,考虑场景匹配的问题 小程...

网友评论

    本文标题:小程序开发十问

    本文链接:https://www.haomeiwen.com/subject/adeddftx.html