SQLite
 sql >> Datenbank >  >> RDS >> SQLite

Uncaught TypeError kann die Methode „opendatabase“ des undefined-SQLite-Plugins mit Cordova 3.5 nicht aufrufen

Die Anweisung in Ihrem Code schlägt fehl, wenn Sie das sqlite-Plug-in nicht eingebunden haben in Ihrem Projekt.

var db = window.sqlitePlugin.openDatabase({name: "test.db"});

Außerdem sollten Sie darauf warten, dass das Deviceready-Ereignis ausgelöst wird, bevor Sie Cordova-Plugins verwenden.
Sie können window.openDatabase() verwenden -Aufruf, der eine SQLite-DB erstellt und das SQLite-Plugin nicht benötigt.
Unten ist der Code für die Verwendung des openDatabase-Aufrufs in Ihrer App.

Wenn Ihr SQLite-Plugin korrekt funktioniert, ändern Sie den DB-Aufruf in.

var db = window.sqlitePlugin.openDatabase({name: "test.db"});

Code, der das SQLite-Plugin nicht verwendet.

// 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!");
    }

Das obige Code-Snippet stammt aus dem Cordova-API-Dokument. Siehe hier für Details. Obwohl die Dokumentation für 3.0 ist, sollte sie für 3.5 funktionieren