小程序云开发出坑系列(一)

小程序云开发出坑系列(一)—初识小程序开发

一、什么是小程序?

1.1 小程序简介

  • 是一种不需要下载安装即可使用的应用,实现应用“触手可及”的梦想,用户扫一扫或搜一下即可打开应用。

1.2 小程序和APP、H5之间的区别

  • 实现原理:

    • 微信小程序的框架包含两部分View视图层、App Service逻辑层,View层用来渲染页面结构,AppService层用来逻辑处理、数据请求、接口调用,它们在两个进程(两个Webview)里运行。
    • 视图层和逻辑层通过系统层的JSBridage进行通信,逻辑层把数据变化通知到视图层,触发视图层页面更新,视图层把触发的事件通知到逻辑层进行业务处理。
    • 系统架构图:
      小程序云开发出坑系列(一)_第1张图片
  • 小程序与APP的区别
    小程序云开发出坑系列(一)_第2张图片

    • 运行环境:
      原生 App 直接运行在操作系统的单独进程中(在 Android 中还可以开启多进程),而小程序只能运行在微信的进程中。
    • 开发成本 :
      原生 App 的开发涉及到 Android/iOS 多个平台、开发工具、开发语言、不同设备的适配等问题;而小程序只需要开发一个就可以在 Android/iOS 等不同平台不同设备上运行。
      原生 App 需要在商店上架(Android 需要上架各种商店);小程序只能在微信平台发布。
    • 系统权限:
      原生 App 调用的是系统资源,也就是说系统提供给开发的的 API 都可以使用;而小程序是基于微信的,小程序所有的功能都受限于微信,也就是说微信给开发者提供 API 才可以使用,不能绕过微信直接使用系统提供的 API。
      原生 App 可以给用户推送消息;小程序不允许主动给用户发送消息,只能回复模版消息 。
      原生 App 有独立的数据库,可以做离线存储;小程序只能存储到 LocalStorage,无法做离线存储。
    • 运行流畅度:
      原生APP运行在操作系统中,所有的原生组件可以直接调用GPU进行渲染;而小程序运行在微信进程中,只能通过WebView进行渲染。
  • 小程序与H5的区别
    小程序云开发出坑系列(一)_第3张图片

    • 运行环境
      简单来说,小程序是一种应用,运行的环境是微信(App);H5 是一种技术,依附的外壳是是浏览器。
      H5 的运行环境是浏览器,包括 WebView,而微信小程序的运行环境并非完整的浏览器,因为小程序的开发过程中只用到一部分H5 技术。
      小程序的运行环境是微信开发团队基于浏览器内核完全重构的一个内置解析器,针对性做了优化,配合自己定义的开发语言标准,提升了小程序的性能。
      小程序中无法使用浏览器中常用的 window 对象和 document 对象,H5 可以随意使用。
    • 开发成本
      H5 的开发,涉及开发工具(vscode、Atom等)、前端框架(Angular、react等)、模块管理工具(Webpack 、Browserify 等)、任务管理工具(Grunt、Gulp等),还有 UI 库选择、接口调用工具(ajax、Fetch Api等)、浏览器兼容性等等。
      尽管这些工具可定制化非常高,大部分开发者也有自己的配置模板,但对于项目中各种外部库的版本迭代、版本升级,这些成本加在一起那就是个不小数目了。
      而开发一个微信小程序,由于微信团队提供了开发者工具,并且规范了开发标准,则简单得多。前端常见的 HTML、CSS 变成了微信自定义的 WXML、WXSS,官方文档中都有明确的使用介绍,开发者按照说明专注写程序就可以了。
      需要调用后端接口时,调用发起请求API;需要上传下载时,调用上传下载API;需要数据缓存时,调用本地存储API;引入地图、使用罗盘、调用支付、调用扫码等等功能都可以直接使用;UI 库方面,框架带有自家 weui 库加成。
      并且在使用这些 API 时,不用考虑浏览器兼容性,不用担心出现 BUG,显而易见微信小程序的开发成本相对低很多。
    • 系统权限
      微信小程序相对于 H5 能获得更多的系统权限,比如:网络通信状态、数据缓存能力等,这些系统级权限都可以和微信小程序无缝衔接。
      而这一点恰巧是 H5 被诟病的地方,这也是 H5 的大多应用场景被定位在业务逻辑简单、功能单一的原因。
    • 运行流畅度
      这条无论对于用户还是开发者来说,都是最直观的感受。长久以来,当HTML5应用面对复杂的业务逻辑或者丰富的页面交互时,它的体验总是不尽人意,需要不断的对项目优化来提升用户体验。但是由于微信小程序运行环境独立,尽管同样用 HTML +CSS + JS 去开发,但配合微信的解析器最终渲染出来的是原生组件的效果,自然体验上将会更进一步。

1.3 移动互联网的八的平台

   IOS、Android、H5、百度、阿里、腾讯、头条、手机厂商

动态App平台阵营(H5、BAT、头条、手机厂商),共有10个超级App、14家公司参与其中,他们是:微信、企业微信、QQ浏览器、支付宝、淘宝、钉钉、手机百度、今日头条、抖音、还有华为、小米、OPPO、VIVO、魅族、金立、联想、中兴、努比亚、一加等10家手机厂商联合成立的快应用联盟。

1.4小程序的发展

下图是艾媒咨询整理的:
小程序云开发出坑系列(一)_第4张图片

二、微信小程序的相关技术有哪些?

2.1 技术概述

  1. 使用 JSON 技术来表现应用的配置信息。包含应用的基本信息,页面配置和路由,应用全体的信息等。
  2. 使用经过定制 HTML+CSS 技术来实现视图层的描述。画面元素,例如列表、按钮、文本框、选择框等都通过 HTML 语言来描述,遵从 HTML 语法,对于页面的共同风格,使用 CSS 进行定义。
  3. 使用 JavaScript 语言来实现逻辑层结构。包括用户操作的处理,系统 API 的调用等。
  4. 架构在视图层和逻辑层之间提供数据和事件传输功能,从而尽量减少难度。由于类似应有都属于轻应用,所以提供的功能都比较单一。

2.2 JSON

  • JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。它基于 ECMAScript(W3C 制定的 JavaScript 规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

2.3 HTML

  • html又称为超文本标记语言(英文:HyperText Markup Language,HTML)是为“网页创建和其它可在网页浏览器中看到的信息”设计的一种标记语言。HTML被用来结构化信息——例如标题、段落和列表等等,也可用来在一定程度上描述文档的外观和语义。1982年由蒂姆·伯纳斯-李创建,由IETF用简化的SGML(标准通用标记语言)语法进行进一步发展的HTML,后来成为国际标准,由万维网联盟(W3C)维护。

2.4 CSS

  • 层叠样式表(英文全称:Cascading Style Sheets)是一种用来表现 HTML 或 XML 等文件样式的计算机语言。CSS 不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。
  • CSS 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象和模型样式编辑的能力。

2.5 JavaScript

  • JavaScript 一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。
  • 在1995年时,由 Netscape 公司的 Brendan Eich,在网景导航者浏览器上首次设计实现而成。因为 Netscape 与 Sun 合作,Netscape 管理层希望它外观看起来像 Java,因此取名为 JavaScript。但实际上它的语法风格与 Self 及 Scheme 较为接近。
  • 为了取得技术优势,微软推出了 JScript,CEnvi 推出 ScriptEase,与 JavaScript 同样可在浏览器上运行。为了统一规格,再加上 JavaScript 兼容于 ECMA 标准,因此也称为 ECMAScript。

三、 如何创建并运行一个小程序?

关于这部分内容,我想大家看看微信公众平台就好。所以这部分就略过了。
微信公众平台:https://mp.weixin.qq.com/

四、下一篇预告

  1. 什么是云开发
  2. 搭建一个云开发项目
  3. 项目解释
  4. 怎么进行协同开发(腾讯的蜂工+TGit)
  5. 协同开发中的一些小坑

你可能感兴趣的:(微信小程序)