Wyrażenie w kodzie nie powiedzie się, jeśli nie włączysz wtyczki sqlite w Twoim projekcie.
var db = window.sqlitePlugin.openDatabase({name: "test.db"});
Powinieneś także poczekać na uruchomienie zdarzenia deviceready przed użyciem wtyczek cordova.
Możesz użyć window.openDatabase() wywołanie, które tworzy bazę danych sqlite i nie wymaga wtyczki sqlite.
Poniżej znajduje się kod do użycia wywołania openDatabase w Twojej aplikacji.
jeśli twoja wtyczka sqlite działa poprawnie, zmień wywołanie db na.
var db = window.sqlitePlugin.openDatabase({name: "test.db"});
kod, który nie korzysta z wtyczki sqlite.
// Wait for device API libraries to load
//
document.addEventListener("deviceready", onDeviceReady, false);
// device APIs are available
//
function onDeviceReady() {
var db = window.openDatabase("Database", "1.0", "Cordova Demo", 200000);
db.transaction(populateDB, errorCB, successCB);
}
// Populate the database
//
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")');
}
// Transaction error callback
//
function errorCB(err) {
alert("Error processing SQL: "+err);
}
// Transaction success callback
//
function successCB() {
alert("success!");
}
Powyższy fragment kodu pochodzi z dokumentu Cordova API. Zobacz tutaj szczegóły. Mimo że dokumentacja dotyczy wersji 3.0, powinna działać w wersji 3.5