一文带你快速掌握如何读懂 YonBuilder移动开发 的项目源码`
1.读懂代码的第一步,了解项目的整体文件结构
-
CSS: 存放css样式的文件;
-
feature:猜测是用来存放特征文件的,实际开发中没看到真实使用案例,通常不需要,删除即可。
-
html:核心文件夹,存放项目各个页面对应的html文件
-
icon:存放项目的icon图标,仅对本地测试包有效,可删除
-
image:图片资源文件夹
-
launch:存放项目的启动图图片资源,仅对本地测试包有效,可删除
-
res:存放非图片资源的文件夹
-
script:存放通用的js文件,包括一些封装有通用逻辑的js文件,或引用的第三方js框架文件等
-
wgt:用来存放widget子包,根据项目实际需要使用,一般不用,可删除
-
config.xml: 项目的配置文件, 存放关于项目配置的相关信息数据,如入口文件,appid等
-
index.html: 默认的整个app项目的入口文件,当app启动后,会首先读取运行该文件。(可以在config.xml中重新修改设置程序的入口文件)
PS: 上面的截图是通常在创建一个新的项目时,系统会自动帮你创建好的项目文件结构,对于一个新的项目,处于简化项目代码的需要,建议可将其中的
feature
、icon
、launch
、wgt
均可删除掉,不影响正常的代码逻辑。上面介绍的这些,属于一个项目的核心文件机构,有兴趣的小伙伴,可点击Widget包结构说明了解更多
2.读懂代码的第二步,找到程序的入口文件
通常一个项目的入口文件是根目录下的index.html文件,这个文件是创建应用时,系统默认的。但是这个入口配置是可以在config.xml中修改的,所以如果我们要查看一个项目,首先需要打开应用根目录下的 config.xml 文件,查看一下这个项目的入口文件位置。
在YonStudio开发工具下,config.xml
被可视化了,它的入门文件位置见下截图
我们也可以点击上面截图中导航条右侧的源文件
文字,去查看真正的config.xml页面源码
PS: 当我们再github或者gitee等开源仓库下载一个YonBuilder移动开发项目代码时,如果我们想要运行体验一下代码,那么就需要在config.xml中,将appid的值,修改成我们账户下自己的一个应用项目的appid才行,因为通常我们只能运行和调式自己账户下的应用。特别是如果一些项目引用了一些移动插件,那么我们就需要在云端控制台自己的项目中,同步添加这些移动插件才OK,否则运行就会报错。
有兴趣的小伙伴,可点击config.xml的配置说明在线文档了解更多
3.读懂代码的第三步,了解 HTML文件的编码结构
3.1 html文件编码结构简述
使用YonBuilder
移动开发技术,开发出的App
项目,其每一个用户可见的页面,必定由一个(=1)win
窗口和若干个(≥0)frame
窗口组合而成,每一个win
或者frame
窗口组件,都对应着一个唯一的html
页面,所以读懂html
文件,是掌握YonBuilder
移动开发技术的关键。
一个完整的html文件的基本结构描述如下:
<html>
<!--head主要包含页面的meta元数据描述-->
<head>
<!--页面的meta元数据描述-->
<meta></meta>
<!--页面的标题,在移动端没有意义-->
<title><title>
<!--页面的资源引用,主要用于引用第三方的css样式文件(支持本地和远程)-->
<link><link>
<!--页面内dom引用的class样式-->
<style><style>
<head>
<!--页面的主要结构部分,存放页面结构与内容的dom标签-->
<body></body>
<!--主要存放页面的逻辑代码,也可以通过src属性来引用本地或远程的第三方js框架文件-->
<script>
<!--非常重要:整个html的入口函数,html页面在被加载完成之后,引擎就会自动调用该函数执行-->
apiready = function () {
<!--整个页面的入口运行函数,核心!重要!-->
}
</script>
</html>
由上面我们可以看出,在App
开发中使用的html
结构与web
端开发使用的html
结构没有什么不同,其结构是保持一致的,这一特性会更方面擅长Web
开发的同学迅速上手YonBuilder移动开发
。唯一不同的一点是YonBuilder移动开发
特有的apiready
函数,下面我们就重点介绍一下这个函数。
3.2 apiready函数
apiready是一个生命周期事件函数,它是单个html
文件的入口自运行函数,其特性有点类似window.onload
事件,它的运行时机是当引擎加载完成html
页面,并在页面内的window
对象下挂载api
对象成功后,进行调用运行。
整个html加载的运行机制,见下图
这一运行机制会使得开发者更方便的去阅读相关的项目源码,理解整个页面的编程思路和代码逻辑。
同时,这里也说明一下,apiready
函数的重要性,即为什么要特别设计出这一一个函数。
引入apiready
函数的最根本原因就是在进行YonBuilder移动开发
的时候,我们会根据业务逻辑的需要,频繁的使用到大量的引擎内置的api对象函数方法。
这些api
对象方法是YonBuilder
移动开发引擎环境所特有的,在原本的浏览器环境中并不存在,所以需要引擎在加载html
页面时,去动态注入api
对象后,在相关的程序方法中才可以正常调用,否则就会报错。而apiready
函数就是一个显性的生命周期事件,是引擎用来告诉程序,现在api
对象已经加载完毕,可以正常调用了。
综上所述,新手开发者朋友们,在你编写项目代码时,如果程序使用了相关的api函数,那么一定要保证这个程序方法是在apiready生命周期事件后再被调用执行,一定不能在apiready函数执行前就运行,否则程序就会异常报错。如果定义的函数体内没有使用到相关的api对象,就不受这个限制。
4.读懂代码的第四步,了解「移动插件」这个特殊存在
在一些项目代码中,我们会看到很多语句编码中使用到了 api.require 这个函数对象,例如
var bMap = api.require('bMap');
这种require
对象的方法,就是YonBuilder移动开发
在项目代码中引用原生的移动插件的一种调用方法。通过 api.require
函数,可以初始化一个移动插件的实例对象,后面就可以通过这个实例对象来调用该移动插件内部已经封装好的api方法,从而快速实现需要的编码功能。
关于「移动插件」,简单来说是YonBuilder移动开发的一种扩展机制,在移动端进行代码开发,有时候我们会遇到一些特殊场景是不适合使用HTML方式去实现的,例如
- 场景下需要实现的一些功能是移动平台所特有的,原生的HTML环境不具备或者无法实现,比如调用手机相机、通讯录、定位、闹铃、消息通知等;
- 场景下一些功能比较耗费性能,虽然可以使用原生HTML去实现,但实现后运行的性能和体验不够理想,比如上千条的列表数据(如5000人的通讯录列表),使用html+js方式去实现,滑动页面列表时,就会出现页面的卡顿问题;
- 场景需要使用一些第三方平台的功能,即需要调用第三方平台移动端封装好的SDK,比如 百度(高德)地图的SDK、人脸识别、直播、客服等等功能,他们这些平台封装的都是android或者iOS的原生SDK安装包,在HTML的web环境无法直接调用;
鉴于以上的场景需要,YonBuilder移动开发在引擎层提供了一种机制,就是可以使用引擎提供的一套特定的框架方法,可以将使用android或者iOS原生语言开发的SDK进行封装,封装后的程序可以直接被JavaScript进行调用使用。这个封装好的程序包,就被叫做「移动插件」,或「移动原生插件」。
移动插件需要在云端的应用程序控制台去进行添加,通过「移动打包」进行编译,才可以在具体的项目代码中进行调用。所以我们在遇到使用api.require调用移动插件时,如果想了解具体的插件api功能,就可以访问网站去查看对应的移动插件开发文档,里面有详细的介绍。具体的插件名称就是require括号内的名称,如上面的api.require('bMap')
, 其中的单引号包含的 bMap
就是具体的插件名称。
未登录情况下在「资源市场」下查看移动插件
已登录情况下,可以在租户下-「移动开发」-「移动插件」下的「已添加插件」或「移动插件库」去查看移动插件
总结
上面的简单讲述,其目的是让新手开发者朋友们对YonBuilder移动开发的项目代码的项目结构、运行机制和编码流程有了一个整体上的快速了解。了解以后,一些已经具备Web开发能力的小伙伴们,就可以通过阅读他人项目代码,来快速掌握和提高自己的YonBuilder移动开发技术水平了。
想要学习更多,可点击YonBuilder移动开发官方文档进行了解和学习。