我如何在离子2中设置全局变量



当我使用sqlite时,需要一直重新打开数据酶,andi这太糟糕了。我如何使用SQLite实例创建/设置一个全局变量以在组件之间共享它?

简单示例:

app/app.ts

export class MyApp {
    constructor(public platform: Platform) {
        this.platform.ready().then(() => {
            @SetGlobal();
            let databaseInstance = new SQLite();
        });
    }
}

home/home.ts

export class HomePage {
    constructor(public platform: Platform, databaseInstance) {
        databaseInstance.then(() => {
            databaseInstance.executeSql('create table demo(name VARCHAR(32))', {}).then(() => {
            }, (err) => {
                console.error('Unable to execute sql: ', err);
            });
        }, (err) => {
            console.error('Unable to open database: ', err);
        });
    }
}

主要思想就是将连接保持在共享服务中,以确保您只有一个活着的连接。如果您仅在app.module.ts上提供此服务,则此服务将是单身实例,这就是您想要的。

数据库服务:

@Injectable()
export class DatabaseService {
    public instance = null;
    constructor(){
        this.instance = new SQLite();
    }
}

app.module.ts:

@NgModule({
  ...
  providers: [
    ...
    DatabaseService
  ]
})
export class AppModule {}

home.ts:

export class HomePage {
    constructor(public platform: Platform, dbService: DatabaseService) {
        dbService.instance.then(() => {
            dbService.instance.executeSql('create table demo(name VARCHAR(32))', {}).then(() => {
            }, (err) => {
                console.error('Unable to execute sql: ', err);
            });
        }, (err) => {
            console.error('Unable to open database: ', err);
        });
    }
}

相关内容

  • 没有找到相关文章

最新更新