首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用数据库API接口的Chrome扩展

使用数据库API接口的Chrome扩展
EN

Stack Overflow用户
提问于 2011-06-28 10:14:44
回答 1查看 1.7K关注 0票数 0

我想用我在chrome的本地数据库中生成的锚点列表来更新div。这是非常简单的东西,但是当我试图通过回调将数据添加到main.js文件时,一切突然变得不确定了。或者数组长度设置为0。(当它真的是18岁时。)

最初,我尝试将它安装到一个新的数组中,然后以这种方式将其传递回去。

为了允许与数据库manifest.json通信,是否需要在chrome API中指定设置?我查过了,但我所能找到的只有“无限存储空间”。

代码如下:

代码语言:javascript
复制
    window.main = {};
window.main.classes = {};
(function(awe){
    awe.Data = function(opts){
      opts = opts || new Object();
      return this.init(opts);
    };
    awe.Data.prototype = {
        init:function(opts){
            var self = this;
            self.modified = true;

            var db = self.db = openDatabase("buddy","1.0","LocalDatabase",200000);
            db.transaction(function(tx){
                tx.executeSql("CREATE TABLE IF NOT EXISTS listing ( name TEXT UNIQUE, url TEXT UNIQUE)",[],function(tx,rs){
                    $.each(window.rr,function(index,item){
                        var i = "INSERT INTO listing (name,url)VALUES('"+item.name+"','"+item.url+"')";
                        tx.executeSql(i,[],null,null);
                    });
                },function(tx,error){

                });
            });
            self._load()
            return this;
        },
        add:function(item){
            var self = this;
            self.modified = true;
            self.db.transaction(function(tx){
                tx.executeSql("INSERT INTO listing (name,url)VALUES(?,?)",[item.name,item.url],function(tx,rs){
                    //console.log('success',tx,rs)
                },function(tx,error){
                    //console.log('error',error)
                })
            });
            self._load()
        },
        remove:function(item){
            var self = this;
            self.modified = true;
            self.db.transaction(function(tx){
                tx.executeSql("DELETE FROM listing where name='"+item.name+"'",[],function(tx,rs){
                    //console.log('success',tx,rs)
                },function(tx,error){
                    //console.log('error',tx,error);
                });
            });
            self._load()
        },
        _load:function(callback){
            var self = this;
            if(!self.modified)
                return;
            self.data = new Array();
            self.db.transaction(function(tx){
                tx.executeSql('SELECT name,url FROM listing',[],function(tx,rs){
                    console.log(callback)
                    for(var i = 0; i<rs.rows.length;i++)
                    {

                        callback(rs.rows.item(i).name,rs.rows.item(i).url)
                        // var row = rs.rows.item(i)
                        // var n = new Object()
                        // n['name'] = row['name'];
                        // n['url'] = row['url'];
                    }
                },function(tx,error){
                    //console.log('error',tx,error)
                })
            })
            self.modified = false
        },
        all:function(cb){
            this._load(cb)
        },
        toString:function(){
            return 'main.Database'
        }
    }
})(window.main.classes);

和更新列表的代码。

代码语言:javascript
复制
this.database.all(function(name,url){
       console.log('name','url')
       console.log(name,url)

       var data = []
       $.each(data,function(index,item){
           try{
               var node = $('<div > <a href="'+item.url+'">'+item.name + '</a></div>');
               self.content.append(node);
               node.unbind();
               node.bind('click',function(evt){
                   var t = $(evt.target).attr('href');
                   chrome.tabs.create({
                       "url":t
                   },function(evt){
                       self._tab_index = evt.index
                   });
               });
           }catch(e){
               console.log(e)
           }
       })    
   });
EN

回答 1

Stack Overflow用户

发布于 2011-06-30 12:39:14

通过查看上面的代码,我注意到您在API中的每个函数的末尾执行了"self._load()“。HTML5数据库是异步的,你永远不能保证结果。在这种情况下,我会假设结果总是0或随机的,因为这将是一个竞争条件。

我已经在我的fb-exporter扩展中做了类似的事情,请随意看看我是如何做到的https://github.com/mohamedmansour/fb-exporter/blob/master/js/database.js

要解决这样的问题,您是否检查了Web Inspector并查看后台页面中是否出现任何错误。我想这一切都在背景页面中,对吧?尝试查看是否发生任何错误,如果没有,我相信您遇到了竞争条件。只需在回调中移动load,它就应该正确地调用load。

关于unlimited storage清单属性的第一个问题,在这种情况下不需要它,这不应该是问题所在。web数据库的限制是5MB (据我所知,它可能已经改变了),如果你使用了大量的数据操作,那么你就可以使用这个属性。

只需确保在初始化数据库后this.database.all仍在运行即可。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6500869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档