美文网首页AppWorker
AppWorker教程-公共函数

AppWorker教程-公共函数

作者: wtcgzh | 来源:发表于2018-06-20 16:51 被阅读0次

公共函数

AppWorker平台通常的逻辑代码都是在ui文件对应的ui.js里编写,ui.js是随ui文件自动生成的。我们通常也需要自定义一些js模块,封装一些javascript代码作为函数可以被重复调用。
我们通过一个demo来说明这个问题。

创建js文件

source下的script下创建一个自己的js文件,可以创建子目录,但是<mark>极力推荐只放在</mark>source/script这个根目录下

放在别的目录下也可以,包括放在data:// 下,但是如果要加密,只会加密这个source/script下的js文件,所以推荐只放在source/script下

image
在这个demo里定义了2个js文件,一个是souce://script/util.jssource://script/ui/util.js

定义和声明函数

在这个js文件里正常定义js的函数,然后利用module.exports声明这个函数可以被外部使用

注意:在自定义的js文件里使用AppWorker的函数和API,需要先额外加载一下AppWorker的库,参考示例第一句

//声明
module.exports.encode = base64encode;
module.exports.decode = base64decode;

.....

function base64encode(str) { //通过JavaScript实现base64编码
   ......
    return out;  
}

var alg = d1.sm("do_Algorithm");
function base64decode(str) {//通过AppWorker的do_Algorithm组件来实现base64的解码
        return alg.base64Sync("decode",str);
}

这个例子里我们定义了三个函数

  1. base64的编码的encode函数。定义在source/script/util.js
  2. base64的解码的decode函数。定义在source/script/util.js
  3. 定义返回按钮closepage的功能的init函数。定义在source/script/ui/util.js

使用函数

使用这个函数,需要先调用require方法加载你自己定义的js模块,require里的参数就是你定义的js名字,注意<mark>不需要加扩展名</mark>

var nf = sm("do_Notification");
var util = require("util");//加载source/script/util.js模块
//也可以写成require("source://script/util");不要后缀
var ui_util = require("ui/util");//加载source/script/ui/util.js模块
//也可以写成require("source://script/ui/util");不要后缀
//返回按钮
ui_util.init("close");

//
.....
encodeButton.on("touch", function() {
        var src = srcTextBox.text;
        var dest = util.encode(src);
        destTextBox.text = dest;
})

decodeButton.on("touch", function() {
        var src = destTextBox.text;
        var dest = util.decode(src);
        srcTextBox.text = dest;
})

这个demo点击 Base64编码按钮把用户输入的字符串转成base64字符串,点击Base64解码再把base64字符串返回原字符串

image

这个demo详细参考这里

注意:我们如果通过do_Webview组件加载html和js文件的话,规则和常规的web方式一样,通过<script>标签,这里就不介绍了。

相关文章

  • AppWorker教程-公共函数

    公共函数 AppWorker平台通常的逻辑代码都是在ui文件对应的ui.js里编写,ui.js是随ui文件自动生成...

  • AppWorker教程-动画

    动画 动画效果在移动App开发中非常重要,好的体验很多都体现在用户不会轻易察觉的动画效果中。html5的动画效果现...

  • AppWorker教程-基础-介绍

    一. AppWorker是什么? AppWorker是一个移动开发的平台或技术,与之对等的是Android移动开发...

  • AppWorker教程-页面跳转

    页面跳转 Page是AppWorker应用中最重要的概念,我们详细介绍Page的一下相关问题,相关的App和UI的...

  • AppWorker教程-数据绑定

    数据绑定 数据绑定是在应用程序 UI 与数据源建立连接的过程。如果绑定正确数据,则当数据更改其值时,绑定到数据的U...

  • AppWorker教程-IDE使用

    IDE安装和使用 设计器是基于Eclipse RCP开发的,如果熟悉Eclipse的同学可能比较容易上手,常见问题...

  • AppWorker教程-网络传输

    网络传输(Http) 注意:官方推出了类似ajax的封装js库,如果对ajax熟悉,可以直接使用,下载地址do_H...

  • AppWorker教程-事件机制

    事件和消息机制的介绍 消息/事件机制是几乎所有开发语言都有的机制,并不是AppWorker的独创,在某些语言称之为...

  • AppWorker教程-UI复用

    UI复用 模板复用机制是android,ios等移动开发技术中类似listview,gridview,slidev...

  • AppWorker教程-应用升级

    应用升级 AppWorker平台的应用升级包含二种升级方式,一种是最常用的安装包的升级,另外一种是应用内升级。很显...

网友评论

    本文标题:AppWorker教程-公共函数

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