深入浅析JavaScript中数据共享和数据传递(2)

// 创建一个app作用域的sqlite对象,第二个参数是这个对象的标示,第三个参数标示作用域是app var sqlite_app = mm("do_SQLite", "sqlite_app_id1", "app") function test_sqlite() { // 在index.ui.js里利用这个对象创建一个数据库test.db sqlite_app.open("data://test.db"); var stu_table = "drop table if exists stu_table" // 同步执行一个SQL语句 sqlite_app.executeSync(stu_table); // 创建表SQL语句 stu_table = "create table stu_table(_id integer primary key autoincrement,sname text,snumber text)"; // 同步执行一个SQL语句 sqlite_app.executeSync(stu_table); var stu_sql = "insert into stu_table(sname,snumber) values('xiaoming','01005');" + "insert into stu_table(sname,snumber) values('xiaohong','01006');" + "insert into stu_table(sname,snumber) values('xiaoliu','01007')"; // 异步执行一个SQL语句 sqlite_app.execute(stu_sql, function(data, e) { // 回调到这里才真正把数据插入完,如果在执行到这里之前去查询数据有可能读不到数据 deviceone.print("insert finished!") }) // 根据"sqlite_app_id1"这个id获取一个app作用域的sqlite对象,第二个参数是这个对象的标示,第三个参数标示作用域是app var sqlite_app = mm("do_SQLite", "sqlite_app_id1", "app") // 在sqlite/index.ui.js里利用这个对象查询test.db,因为这个对象已经打开了数据库,所以不需要再open了 // 创建查询SQL语句 var stu_query = "select * from stu_table"; // 同步执行一个查询语句 var result = sqlite_app.querySync(stu_query); label.text = "在sqlite/index.ui.js里利用这个对象查询test.db里的stu_table表的第二条数据\n" + JSON.stringify(result[1], null, 2);

2. page作用域:

// 创建一个page作用域的sqlite对象,唯一的id标示是memory_db_id1 var sqlite_app = mm("do_SQLite", "memory_db_id1", "page"); // 在test1.ui.js里利用这个对象创建一个内存数据库,这个名字必须写死是:memory: sqlite_app.open(":memory:"); // 创建表SQL语句 var stu_table = "drop table if exists stu_table;" // 内存数据库执行速度快,可以尝试都用同步 // 同步执行一个SQL语句 sqlite_app.executeSync(stu_table); stu_table = "create table stu_table(_id integer primary key autoincrement,sname text,snumber text)"; // 同步执行一个SQL语句 sqlite_app.executeSync(stu_table); var stu_sql = "insert into stu_table(sname,snumber) values('laoming','1');" + "insert into stu_table(sname,snumber) values('laohong','2');" + "insert into stu_table(sname,snumber) values('laoliu','3')"; // 同步执行一个SQL语句 sqlite_app.executeSync(stu_sql); // 在test2.ui.js里查询在test1.ui.js里创建的数据库表 // 根据memory_db_id1这个标示来获取已经创建好的sqlite对象 var sqlite_app = mm("do_SQLite", "memory_db_id1", "page"); // 创建查询SQL语句 var stu_query = "select * from stu_table"; // 同步执行一个查询语句 var result = sqlite_app.querySync(stu_query); label.text = "在test2.ui.js里查询在test1.ui.js里创建的内存数据库表的第三条记录\n" + JSON.stringify(result[2], null, 2)

数据传递

数据传递涉及到跨作用域,比如不同的ui文件传递数据,不同的page传递数据。

其中最重要也是最常用的方式就是消息机制

1.消息机制

这个环节我们在文档再里详细介绍。

总之,消息机制可以在跨ui作用域传递数据,也可以跨page作用域传递数据。

2.openPage和closePage传递数据。

这个数据传递是跨page作用域,但是只限于相隔二层page之间。比如在page1的基础上打开page2,page1把一些数据传递给page2;page2关闭自身,露出page1,又可以把数据传递回page1. 数据传递可以是任何json对象。
这是一个常规而且非常好的方式,建议都这么使用。

// 在index.ui.js里openPage页面open_close_page/index.ui,传递数据 var d = { "k1" : "v1", "k2" : "v2", "k3" : "v3", "k4" : "v4" }; app.openPage({ source : "source://view/open_close_page/index.ui", data : d, statusBarState : "transparent" }); } // 接受页面open_close_page/index.ui 关闭的时候传递回来的数据 page.on("result", function(data) { if (data) nf.alert(JSON.stringify(data, null, 2)); }) // 从index.ui.js传递过来的数据通过getData获取值,可直接返回json对象 var data = page.getData(); label.text = "从index.ui.js传递过来的数据通过getData获取值,可直接返回json对象 \n" + JSON.stringify(data, null, 2);// 格式化 function close_me() { // 关闭自身,把数据传递回下一层page app.closePage("我是从open_close_page/index.ui关闭的时候传递过来的数据"); }

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wgyyxg.html