微信小程序介绍
发表时间:2020-10-19
发布人:葵宇科技
浏览次数:58
无处不在的小程序
从 2017 年 1 月 9 日,张小龙在 2017 微信公开课 Pro 上发布小程序开始算起,微信小程序已经走过了三个年头。从当初的只闻其名到今天的耳濡目染,微信小程序可以说已经深入了每个人的生活。读者可以打开自己手机微信,进入微信页面并上滑,就可以看到和下图相似的微信小程序管理画面。
如果再点一下 […] 图标,你会看到更多的小程序。而这些小程序,你大概已经记不得是什么时候进到手机里的了…
快速发展的轻应用
除了在微信中运行的微信小程序之外,还存在众多的「小程序表亲」。例如,有多家手机硬件厂商支持的快应用,就是一个典型的例子。
到目前为止,我们知道的的主流厂商几乎都参加了快应用联盟。
快应用的架构,采用的技术 (XML/JSON/JavaScript)和微信小程序几乎完全相同。(参考资料:轻应用开发文档)
可以毫不夸张地说,掌握了小程序开发技术,就等于打通了手机应用开发蓝海的出海口!
什么是微信小程序?
微信小程序这个词可以分解为「微信」和「小程序」两部分。
其中微信可以理解为「微信中的」,指的是小程序的执行环境;当然微信在提供执行环境的同时也延长了用户使用微信的时间。
「小程序」是说它首先是程序,然后具备轻便的特征。小程序并不像其他应用那样需要安装,而是通过扫描二维码打开后直接执行;用完以后也不需要卸载。这就是所谓用完即走的原则。
另外,微信不会提供类似于小程序商店的地方,需要小程序提供者自己通过二维码,群分享的手段来传播,这就是所谓去中心化的形态。
微信朋友圈提供了好友之间沟通信息的手段,订阅号提供了面向粉丝推送信息的手段,而小程序则是提供了用户通过自己的操作而与服务实现互动的手段。
小程序相关技术
由于本专栏的目标读者是了解基本的 C/C++ 语法,但对小程序开发完全没有经验的程序员,所以我们会在说明微信小程序的同时,对相关技术也进行相应的介绍。通过这种方式,我希望读者们能够专注于小程序的开发,而不是因为到处寻找资料而导致忘了学习微信小程序的本来目的。换一种说法就是:并不需要另外自己调查,跟着本专栏走下去就好。
微信小程序推出三年多的时间,算是一个新事物,但利用的技术却都是存在已久的技术。稍加调查你就会发现,不光是微信小程序,很多类似形态的应用都采用类似的架构:
使用 JSON 技术来表现应用的配置信息。包含应用的基本信息、页面配置和路由、应用全体的信息等。
使用经过定制 CSS+XML 技术来实现视图层的描述。画面元素(包括噢列表、按钮、文本框、选择框等)都通过 XML 语言来描述,遵从 XML 语法。对于页面的共同风格,使用 CSS 进行定义。
使用 JavaScript 语言来实现逻辑层结构。包括用户操作的处理,系统 API 的调用等。
架构在视图层和逻辑层之间提供数据和事件传输功能,从而尽量减少复杂度。由于类似应用都属于轻应用,因此提供的功能都比较单一。
具体的语法、用途等我将会在使用的时候详细介绍,这里只提一下相关技术的基本情况,了解即可。
以下是对小程序所涉技术的概括性描述,内容来自百度百科。
JSON
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。它基于 ECMAScript(w3c 制定的 js 规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人的阅读和编写,同时也易于机器解析和生成,并有效提升网络传输效率。
XML
XML(Extensible Markup Language),中文名可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。
在电子计算机中,标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种的信息比如文章等。它可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 它非常适合万维网传输,提供统一的方法来描述和交换独立于应用程序或供应商的结构化数据。是 Internet 环境中跨平台的、依赖于内容的技术,也是当今处理分布式结构信息的有效工具。早在 1998 年,W3C 就发布了 XML 1.0 规范,使用它来简化 Internet 的文档信息传输。
CSS
层叠样式表(Cascading Style Sheets)是一种用来表现 HTML(标准通用标记语言的一个应用)或 XML(标准通用标记语言的一个子集)等文件样式的计算机语言。CSS 不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。
CSS 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象和模型样式编辑的能力。
JavaScript
JavaScript,一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML(标准通用标记语言下的一个应用)网页上使用,用来给 HTML 网页增加动态功能。
在 1995 年时,由 Netscape 公司的 Brendan Eich,在网景导航者浏览器上首次设计实现而成。因为 Netscape 与 Sun 合作,Netscape 管理层希望它外观看起来像 Java,因此取名为 JavaScript。但实际上它的语法风格与 Self 及 Scheme 较为接近。
为了取得技术优势,微软推出了 JScript,CEnvi 推出 ScriptEase,与 JavaScript 同样可在浏览器上运行。为了统一规格,因为 JavaScript 兼容于 ECMA 标准,因此也称为 ECMAScript。
学习方法
微信小程序虽然是新事物,但学习方法却不是新的。
我们的方法是,首先完成一个最简单的小程序实例,通过这个实例介绍微信小程序的构造和想法,这是所谓的「学」。然后扩展这些知识点,通过开发一个简单的小程序来运用这些知识点,这是「习」的过程。
这是作者这些年来屡试不爽的方法。
参考资料
在学习和开发的过程中,我们会参考微信的开发文档。其原因是小程序太新了,相应的知识储备还不够丰富。虽然也可以找到一些开发方面的书籍,但是说实话,内容并不比微信本身的开发文档更详尽。
小程序开发文档