php – 为什么db.transaction不能与indexeddb一起使用?

前端之家收集整理的这篇文章主要介绍了php – 为什么db.transaction不能与indexeddb一起使用?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我是使用inxededdb的新手,我试图从商店中获取数据.存储包含数据,但由于某种原因,代码在尝试设置var tx后停止.如果我遗失任何内容,请告诉我.以下是我试图获取该书的功能
function getBook(){
    var tx = db.transaction("book","readonly");
    var store = tx.objectStore("book");
    var index = store.index("by_getid");

    var request = index.get("<?PHP echo $_GET['book'] ?>");
    request.onsuccess = function() {
      var matching = request.result;
      if (matching !== undefined) {
         document.getElementById("text-container").innerHTML = matching.text;
      } else {
        alert('no match');
        report(null);
      }
    };
}

解决版本:

function getBook(){
    var db;
    var request = indexedDB.open("library",1);  

    request.onsuccess = function (evt) {
    db = request.result; 
    var transaction = db.transaction(["book"]);
    var objectStore = transaction.objectStore("book");
    var requesttrans = objectStore.get(<?PHP echo $_GET['book'] ?>);

        requesttrans.onerror = function(event) {

        };

        requesttrans.onsuccess = function(event) {
            alert(requesttrans.result.text);
        };

    };
}
问题可能是你的db变量.您可能正在访问连接对象的已关闭或null实例.

请尝试在函数内部创建数据库连接.不要使用全局db变量.

猜你在找的PHP相关文章