J'utilise Realm pour la première fois et j'essaie simplement d'initialiser une base de données et de lui écrire un enregistrement. Voici mon code.Pourquoi l'objet de domaine est indéfini dans react-native
import React, { Component } from 'react';
import {StackNavigator} from 'react-navigation';
import Realm from 'realm';
import {
AppRegistry,
StyleSheet,
Text,
View,
Linking
} from 'react-native';
class Home extends Component {
static navigationOptions = {
title: 'Login',
headerStyle: {
backgroundColor:'#000000'
},
headerTitleStyle: {
color:'#fff'
}
};
initDB()
{
const realm = new Realm({schema: [CompatibilityProduct]});
this.realm = realm;
console.log(realm);
};
loadResults()
{
const realm = this.realm;
console.log(realm);
// Write
realm.write(() => {
realm.create('CompatibilityProduct', {
compatibilityId: 18,
productId: 17,
});
});
};
constructor(props)
{
super(props);
}
render() {
const {navigate} = this.props.navigation;
return (
<View>
<Text onPress={this.initDB}>
Init DB
</Text>
<Text onPress={this.loadResults}>
Load Results
</Text>
</View>
);
}
}
const myscreens = StackNavigator({
Home: {screen: Home}
});
class CompatibilityProduct {}
CompatibilityProduct.schema = {
name: 'CompatibilityProduct',
properties: {
compatibilityId: {type: 'int'},
productId: {type: 'int'},
},
};
export default myscreens;
je démarre l'application dans mon AVD, je clique sur Init DB (console.log(realm) is empty in the initDB() function)
, puis quand je clique sur les résultats de charge, les accidents d'application, car this.realm
est non défini.
Qu'est-ce que je fais mal?