2017-05-02 2 views
2

영역 목록을 영역 목록과 함께 사용하려면 목록을 만들 수 없습니다.영역의 목록 속성은 어떻게 작동합니까?

:
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) 
    }); 
    } 
나는

UserListSchema

,691를 사용하여 목록 속성을 만들려고

성공하지 못했습니다. 나는 소스로

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' } } 
+0

당신이 심각 사람이 에세이를 읽을 것으로 예상합니까? [최소한의 완전하고 검증 가능한 예제를 만드는 방법] – Christoph

답변

2

을 목록 개체. 이 링크를 살펴보고 필요한 경우 추가 설명을 요청하십시오. 게시물 마지막 부분에서는 영역 목록 객체에서 객체를 작성/수정/추가/삭제하는 작업 예제를 제공했습니다.목록을 만들려면 How can I properly copy objects from one Realm object to another object

여기에 간단한 사건, 매우 간단합니다 :

class Letters: Object { 
    var letterList = List<Letter>() 
} 

그래서 당신은 당신이 사용하게 될 오브젝트의 서브 클래스를 알아야 목록을 만들 수 있습니다. (위의 예에서 편지). (항목 - 아래)

, 당신은 객체를 생성 목록에 추가 한 다음 목록에 추가 :

firstList.letterList.append(item) 
+0

안녕하세요, 귀하의 답변입니다. DB 내용을 ListView에 표시하지 않으면 목록 속성을 사용하지 않기로했습니다. 간단히 말해서 ListView의 DataSource를'realm.objects ('dbName')'로 설정하고'cloneWithRows (realm.objects ('dbName')' –

관련 문제