Bha*_*ani 4 javascript sqlite reactjs react-native
我正在使用 react-native-sqlite-storage 中的 SQLite 数据库
我没有得到显示在警报中的结果
它显示未定义
我也尝试不等待和异步
主文件
import DBHelper from './DBHelper.js';
export default class MainFile extends Component {
componentDidMount() {
this.dbTransaction();
}
dbTransaction = async () => {
var value = await DBHelper.getWatchList()
alert(value)
}
.....
}
Run Code Online (Sandbox Code Playgroud)
数据库助手
import React, {Component} from 'react';
var SQLite = require('react-native-sqlite-storage');
var dbName = "test.db";
var tableName = "tableName";
const DBHelper = {
getWatchList: () => {
var db = SQLite.openDatabase({name : dbName, createFromLocation : 1}, openCB,errorCB);
db.transaction( (tx) => {
tx.executeSql("select * from " + tableName,
[], (tx, results) => {
console.log("\n\nQuery completed\n");
var resultItemIdArr = new Array();
for (let i = 0; i < results.rows.length; i++) {
resultItemIdArr.push(results.rows.item(i).itemId);
console.log(results.rows.item(i).itemId);
}
return resultItemIdArr;
});
});
},
}
const errorCB = (err) => {
console.log("SQL Error: " + err);
}
const successCB = () => {
console.log("SQL executed fine");
}
const openCB = () => {
console.log("Database OPENED");
}
export default DBHelper;
Run Code Online (Sandbox Code Playgroud)
我想在警报中打印resultItemIdArr值
您在此处使用回调,db.transaction((tx) => {因此您将resultItemIdArr在回调内部返回。如果库不支持承诺,你应该这样做:
getWatchList: (callback) => {
var db = SQLite.openDatabase({name : dbName, createFromLocation : 1}, openCB,errorCB);
db.transaction( (tx) => {
tx.executeSql("select * from " + tableName,
[], (tx, results) => {
console.log("\n\nQuery completed\n");
var resultItemIdArr = new Array();
for (let i = 0; i < results.rows.length; i++) {
resultItemIdArr.push(results.rows.item(i).itemId);
console.log(results.rows.item(i).itemId);
}
callback(resultItemIdArr);
});
});
},
Run Code Online (Sandbox Code Playgroud)
并getWatchList像这样调用:
dbTransaction = () => {
DBHelper.getWatchList(value=>{
alert(value)
})
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3267 次 |
| 最近记录: |