标签:javascript ios sqlite exception mobile-safari
我有一个在init上调用openDatabase()的webapp.这在桌面浏览器Chrome和Safari中运行良好;但是,当我尝试在iOS 4.3.3上的Mobile Safari中打开应用程序时,我在第一页加载时遇到异常:
“错误:INVALID_STATE_ERROR:DOM异常11”
这在一个简单函数中的openDatabase()上失败:
try {
if( !window.openDatabase) {
console.log('SQLite is not supported by this browser');
}
else {
db = openDatabase('MyMobileDb', '1.0', 'MyMobileDb', 65536);
if (doreset)
{
//my drop and reset DB function
} else
{
//my init DB function
}
}
}
catch(e) {
console.log(e);
}
未创建数据库,也无法与应用程序进一步交互.运行早期版本的iOS的其他开发人员没有遇到针对相同代码bade的此问题.我也从我们的QA团队获得Android报告类似行为的报告. Android 3.1有效,而2.2和2.1则无效.
我该怎么做才能解决这个问题?
解决方法:
我有一些在离线移动应用程序中运行的WebSQL代码,可在iOS 4.3.3和桌面Safari中运行.
INVALID_STATE_ERROR:DOM异常11令人沮丧地不透明,因为它可以引用很多不同的东西,但我怀疑你链接的WebKit问题在你的情况下有答案.无论如何,对可能有帮助的事情……
我的代码中的FWIW我通过“有点”工厂初始化数据库连接,这似乎工作正常,持久化我的应用程序(事实上,我使用数据库连接’工厂’加上第二个原型对象封装了我的所有SQL,有点像Javascript DAO,但为了简洁起见,我会把这一点留下来.
我已经创建了一个带有样本“工厂”的要点(这是我的一些生产代码的推断,所以对任何遗漏都道歉):http://gist.github.com/1044759
此代码将初始化您的数据库连接,并创建相关的表(如果它们尚不存在).
这是一些示例脚本(可能是$(document).ready),它将设置数据库连接:
// Initialise local db
var mydb = new DbConnection().getDb();
要使用连接,只需调用正常的事务Javascript,使用mydb作为数据库位,即:
mydb.transaction(function(transaction){
transaction.executeSql(...
希望有所帮助.
标签:javascript,ios,sqlite,exception,mobile-safari 来源: https://codeday.me/bug/20190726/1542769.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。