标签:javascript parameters firefox storage mozilla
我是Javascript的新手并尝试编写一个firefox附加组件.
我试图将从SQL查询返回的数据传递/提取到调用函数.
它似乎不起作用.
我搜索了有关变量范围的信息,查看了我在本网站上看到的任何相关帖子,并尝试了据说可行的示例,但没有一个适用于我.
我正在使用以下存储信息:
https://developer.mozilla.org/en/Storage
https://developer.mozilla.org/en/mozIStorageStatement
我做错了什么,或者我该怎么做?
我在xp上运行firefox 12.
function Sqlite() {
this.dbConn = "";
this.empty = true;
}
Sqlite.prototype.retrieveData = function(query)
{
var rows = new Array(); // to be returned to the calling function
var stmt = this.dbConn.createStatement(query); // my "select..." statement
stmt.executeAsync ({
handleResult: function(aResultSet)
{
this.empty = false;
var i = 0;
for (let row; row = aResultSet.getNextRow();i++) {
rows[i] = row;
}
},
handleError: function(anError) {
//some code
},
handleCompletion: function(aReason) {
if (this.empty) {
// CODE FOR WHEN STATEMENT EXECUTION IS FINISHED
}
if (aReason == Ci.mozIStorageStatementCallback.REASON_FINISHED) {
document.getElementById("debug").value = rows[0]; //gets the data from the query: [xpconnect wrapped mozIStorageRow]
return true;
}
}
});
document.getElementById("debug").value = rows[0]; //gets undefined
stmt.finalize();
return rows; // the info is no longer available at this point.
}
我真的很感谢你的帮助
解决方法:
你描述问题的方式有点模糊,但是当你写下:
返回行; //此时信息不再可用.
这当然是预料之中的.顾名思义,executeAsync是异步的.这意味着当您调用executeAsync时,操作将安排在以后执行. Javascript具有run-to-completion语义,因此执行将继续,直到到达return rows语句.此时,查询尚未执行!一旦你的函数完成,JS引擎将执行你的异步语句,你的handleCompletion回调将被调用.然后由handleCompletion中的代码根据需要对数据执行任何操作,例如:调用另一个函数来做一些事情.
此外,您的空变量似乎不需要.
handleCompletion: function(aReason) {
if (aReason != Ci.mozIStorageStatementCallback.REASON_FINISHED) {
// something went wrong
} else {
// do something useful with rows
}
},
最后,您需要调用row.getResultByName来获取行中列的值.
标签:javascript,parameters,firefox,storage,mozilla 来源: https://codeday.me/bug/20190626/1290210.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。