分析Android微信小程序开发的运行机制-创新互联

这篇文章主要讲解了“分析Android微信小程序开发的运行机制”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“分析Android微信小程序开发的运行机制”吧!

专注于为中小企业提供成都网站制作、网站建设、外贸网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业路桥免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

01 我们称微信客户端给小程序所提供的环境为宿主环境。小程序借助宿主环境提供的能力,可以完成许多普通网页无法完成的功能。

02 渲染层与逻辑层

wxml,wxss工作在渲染层,JS 脚本工作在逻辑层。小程序的渲染层和逻辑层分别由2个线程管理:

渲染层的界面使用了WebView 进行渲染;小程序一般会有多个页面,所以渲染层存在多个WebView线程.

逻辑层采用JsCore线程运行JS脚本。

线程间的通信由Native(微信客户端)做中转.

03,程序与页面

微信客户端在打开小程序之前,会把整个小程序的代码包下载到本地。

紧接着通过 app.json 的 pages 字段就可以知道你当前小程序的所有页面路径:

{
  "pages":[
    "pages/index/index", --第一个页面
    "pages/logs/logs"
  ]}

小程序启动之后,在 app.js 定义的 App 实例的 onLaunch 回调会被执行.

整个小程序只有一个 App 实例,是全部页面共享的

接下来我们简单看看小程序的一个页面是怎么写的。

你可以观察到 pages/logs/logs 下其实是包括了4种文件的,

logs.json,logs.wxml, logs.wxss, logs.js

微信客户端会先根据 logs.json 配置生成一个界面,顶部的颜色和文字你都可以在这个 json 文件里边定义好。紧接着客户端就会装载这个页面的 WXML 结构和 WXSS 样式。最后客户端会装载 logs.js,你可以看到 logs.js 的大体内容就是:

Page({
  data: { // 参与页面渲染的数据
    logs: []
  },
  onLoad: function () {
    // 页面渲染后 执行
  }})

Page 是一个页面构造器,这个构造器就生成了一个页面。在生成页面的时候,小程序框架会把 data 数据和 index.wxml 一起渲染出最终的结构,于是就得到了你看到的小程序的样子。

在渲染完界面之后,页面实例就会收到一个 onLoad 的回调,你可以在这个回调处理你的逻辑。

04, 组件与API

小程序提供了丰富的组件,比如

为了让开发者可以很方便的调起微信提供的能力,例如获取用户信息、微信支付等等,小程序提供了很多 API 给开发者去使用

需要注意的是:多数 API 的回调都是异步,你需要处理好代码逻辑的异步问题。

比如,

要获取用户的地理位置时,只需要:

wx.getLocation({
  type: 'wgs84',
  success: (res) => {
    var latitude = res.latitude // 纬度
    var longitude = res.longitude // 经度
  }})

调用微信扫一扫能力,只需要:

wx.scanCode({
  success: (res) => {
    console.log(res)
  }})

感谢各位的阅读,以上就是“分析Android微信小程序开发的运行机制”的内容了,经过本文的学习后,相信大家对分析Android微信小程序开发的运行机制这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


当前文章:分析Android微信小程序开发的运行机制-创新互联
新闻来源:http://bzwzjz.com/article/dihdoi.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 四川成都网站制作 成都网站设计 手机网站建设 阿坝网站设计 重庆网站设计 响应式网站设计 网站设计 网站设计制作报价 定制网站设计 网站建设方案 企业网站建设 营销网站建设 网站建设公司 宜宾网站设计 高端网站设计 成都网站建设公司 网站制作 网站制作 成都品牌网站建设 成都营销网站建设 网站建设 广安网站设计