영역 목록을 영역 목록과 함께 사용하려면 목록을 만들 수 없습니다.영역의 목록 속성은 어떻게 작동합니까?
:const Realm = require ('realm');
class UserEntrySchema extends Realm.Object {}
UserEntrySchema.schema = {
name:'User',
primaryKey:'id',
properties:{
id:'int',
name:'string',
username: 'string',
email: 'string',
}
};
class UserListSchema extends Realm.Object {}
UserListSchema.schema = {
name:'UserList',
properties: {
users :{type:'list', objectType:'User'}
}
};
class HistorySchema extends Realm.Object {}
HistorySchema.schema = {
name : 'History',
properties :{
items : {type:'list',objectType:'User'}
}
};
export default new Realm({
schema:[UserEntrySchema,UserListSchema,HistorySchema], schemaVersion:0});
내가 다음 코드를 사용하여 첫 번째 목록보기합니다
realm.js :
나는 아래의 코드 조각을 볼 수있다, 2 개 또는 3의 ListView를 만들 필요가
export default class SearchTabScreen1 extends Component {
constructor(props) {
super(props);
this.state = {
searchText:'',
data:[]
};
}
componentDidMount(){
this.fetchUsers();
}
fetchUsers(){
console.log("FEEEEEETCH");
fetch('http://jsonplaceholder.typicode.com/users')
.then((response) => response.json())
.then((responseJson) => {
this.setState({
data : responseJson
});
var data = this.state.data;
realm.write(() => {
for (var i = 0; i < data.length; i++){
let myUser = realm.create('User',data[i],true);
}
console.log("ALLUSER", realm.objects('User'));
});
})
.catch(function(e) { // Failure callback registartion
alert('Failure fetching data');
console.log(e)
});
}
나는
,691를 사용하여 목록 속성을 만들려고UserListSchema
성공하지 못했습니다. 나는 소스로
realm.objects('User')
을 사용하고 경우에도
그리고 대한
이제이 ListView에 잘 작동합니다.내가 좋아하는지 여부는 잘 모르겠다.
두 번째 ListView는 "검색 기록"입니다. 첫 번째 ListView의 행을 클릭하면 다음 화면이 표시됩니다 (반응 네이티브 탐색 패키지 사용). 영역 목록을 채 웁니다. 나는 역사 목록보기 "에 대한 데이터 소스로이 목록을 사용하고자하는
onPushPress(rowData) {
this.props.navigator.showModal({
title: "Random Title",
screen: "Project.WordDefinition",
passProps: {
definition: rowData.name
}
});
realm.write(() => {
let historyList = realm.create('History',{},true);
historyList.items.push({rowData});
});
}
}
을 나는이 오류가있어 :.
'Property' must be of type number
나는 또한 시도 :
onPushPress(rowData) {
console.log("ROWDATA", rowData);
this.props.navigator.showModal({
title: "Titre",
screen: "AccessiDico.WordDefinition",
passProps: {
definition: rowData.name
}
});
realm.write(() => {
let historyList = realm.create('History',{},true);
historyList.items.push({
id:rowData.id,
name:rowData.name,
username: rowData.username,
email: rowData.email,
});
console.log("ROWDATA",rowData);
console.log("ITEMS",realm.objects('History'));
console.log("List",historyList.items);
});
}
}
을 그리고이있어 오류 :
Attempting to create an object of type 'User' with an existing primary key value
내가 "UserEntrySchema"에서 "내 사용자"를 영역 목록 내에서 사용할 수 없다는 것을 의미합니까?
난 정말 어떤 도움을 주셔서 감사합니다 것, 내가이 하드 붙어 일주일되었습니다 : 1 :
감사합니다!
PS : 역사 목록보기는 코딩 방법은 다음과 같습니다 :
export default class HistoryTabScreen2 extends Component {
constructor(props) {
super(props);
// if you want to listen on navigator events, set this up
//this.props.navigator.setOnNavigatorEvent(this.onNavigatorEvent.bind(this));
const ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
this.state = {
postDataSource: ds.cloneWithRows(realm.objects('History')),
};
}
renderRow(rowData, sectionId, rowId, highlightRow){
return(
<TouchableHighlight onPress={this.onPushPress.bind(this)}>
<View style={styles.row}>
<Text style={styles.rowText}>{rowData.name}</Text>
</View>
</TouchableHighlight>
)
}
render(){
return(
<ListView
dataSource={this.state.postDataSource}
renderRow={this.renderRow.bind(this)}
/>
);
}
그리고 내 rowData 하행의 로그 I리스트 뷰의 행을 클릭 : 난 그냥 대한 질문에 응답
'ROWDATA', { id: 5,
name: 'Chelsey Dietrich',
username: 'Kamren',
email: '[email protected]',
address:
{ street: 'Skiles Walks',
suite: 'Suite 351',
city: 'Roscoeview',
zipcode: '33263',
geo: { lat: '-31.8129', lng: '62.5342' } },
phone: '(254)954-1289',
website: 'demarco.info',
company:
{ name: 'Keebler LLC',
catchPhrase: 'User-centric fault-tolerant solution',
bs: 'revolutionize end-to-end systems' } }
당신이 심각 사람이 에세이를 읽을 것으로 예상합니까? [최소한의 완전하고 검증 가능한 예제를 만드는 방법] – Christoph