我正在使用Phonegap,我正在关注他们网站上的指南,但它给了我这个功能。
function populateDB(tx) {
tx.executeSql('DROP TABLE IF EXISTS DEMO');
tx.executeSql('CREATE TABLE IF NOT EXISTS DEMO (id unique, data)');
tx.executeSql('INSERT INTO DEMO (id, data) VALUES (1, "First row")');
tx.executeSql('INSERT INTO DEMO (id, data) VALUES (2, "Second row")');
}
function errorCB(err) {
alert("Error processing SQL: "+err.code);
}
function successCB() {
alert("success!");
}
var db = window.openDatabase("Database", "1.0", "PhoneGap Demo", 200000);
db.transaction(populateDB, errorCB, successCB);
但是如何将值作为参数传递给那里?有可能做这样的事吗?
function populateDB(tx, values) {
tx.executeSql('CREATE TABLE IF NOT EXISTS DEMO (id unique, data)');
tx.executeSql('INSERT INTO DEMO (id, data) VALUES (values['id'], values['data'])');
}
var db = window.openDatabase("Database", "1.0", "PhoneGap Demo", 200000);
db.transaction(populateDB(values), errorCB, successCB);
我看到可以使用问号,但我找不到明确的教程。
答案 0 :(得分:2)
我认为这就是你所追求的 -
var db = window.openDatabase("Database", "1.0", "PhoneGap Demo", 200000);
var insertValues = {
values1: [1, 'First row'],
values2: [2, 'Second row']
};
doInserts(insertValues);
function doInserts(insertValues) {
db.transaction(function(tx) {
tx.executeSql('DROP TABLE IF EXISTS DEMO');
tx.executeSql('CREATE TABLE IF NOT EXISTS DEMO (id unique, data)');
tx.executeSql(
'INSERT INTO DEMO (id, data) VALUES (?, ?)',
insertValues.values1,
insertSuccess,
insertFail
);
tx.executeSql(
'INSERT INTO DEMO (id, data) VALUES (?, ?)',
insertValues.values2,
insertSuccess,
insertFail
);
});
}
function insertSuccess() {
console.log('insert success');
}
function insertFail(err) {
console.log('insertFail, err.message: ' + err.message);
}
这个东西是异步的,所以如果你想知道你的所有插件什么时候完成,一个有用的技巧是 -