How to use react-native-fs?









up vote
0
down vote

favorite












If componentWillMount() function is running first time, items array is empty. Why?



componentWillMount() 
items.splice(0, items.length);
RNFS.readDir(RNFS.DocumentDirectoryPath)
.then((result) =>
console.warn('result: ', result); // debug

for(var i = 0; i < result.length; i++)
if(result[i].name.endsWith('.txt'))
var tmp = result[i].name;
console.warn(tmp); // debug
items.push(tmp);


)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(items); // empty



And using readFile() for get .txt's content, con is empty



renderItem(item) 
return (
<View style = styles.renderItemContainer
key=items.indexOf(item) >
<TouchableOpacity style=styles.renderItemTouchableOpacity
onPress = () =>
fileName = item;

var path = RNFS.DocumentDirectoryPath + '/' + fileName;

RNFS.readFile(path, 'utf8')
.then((contents) =>
console.warn(contents);
con = contents; // not working
)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(con); // empty

this.props.navigation.navigate('editorScreen');
>
<Text style = styles.renderItemText>
item
</Text>
</TouchableOpacity>
</View>
);



in render() function, using items array for list .txt files in ScrollView



render() 
return(
....
<ScrollView>

items.map((items) => this.renderItem(items))

</ScrollView>
....
);










share|improve this question







New contributor




Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.



















  • Your console.warn is being executed before your Promise has resolved.
    – Dan
    Nov 9 at 15:14














up vote
0
down vote

favorite












If componentWillMount() function is running first time, items array is empty. Why?



componentWillMount() 
items.splice(0, items.length);
RNFS.readDir(RNFS.DocumentDirectoryPath)
.then((result) =>
console.warn('result: ', result); // debug

for(var i = 0; i < result.length; i++)
if(result[i].name.endsWith('.txt'))
var tmp = result[i].name;
console.warn(tmp); // debug
items.push(tmp);


)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(items); // empty



And using readFile() for get .txt's content, con is empty



renderItem(item) 
return (
<View style = styles.renderItemContainer
key=items.indexOf(item) >
<TouchableOpacity style=styles.renderItemTouchableOpacity
onPress = () =>
fileName = item;

var path = RNFS.DocumentDirectoryPath + '/' + fileName;

RNFS.readFile(path, 'utf8')
.then((contents) =>
console.warn(contents);
con = contents; // not working
)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(con); // empty

this.props.navigation.navigate('editorScreen');
>
<Text style = styles.renderItemText>
item
</Text>
</TouchableOpacity>
</View>
);



in render() function, using items array for list .txt files in ScrollView



render() 
return(
....
<ScrollView>

items.map((items) => this.renderItem(items))

</ScrollView>
....
);










share|improve this question







New contributor




Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.



















  • Your console.warn is being executed before your Promise has resolved.
    – Dan
    Nov 9 at 15:14












up vote
0
down vote

favorite









up vote
0
down vote

favorite











If componentWillMount() function is running first time, items array is empty. Why?



componentWillMount() 
items.splice(0, items.length);
RNFS.readDir(RNFS.DocumentDirectoryPath)
.then((result) =>
console.warn('result: ', result); // debug

for(var i = 0; i < result.length; i++)
if(result[i].name.endsWith('.txt'))
var tmp = result[i].name;
console.warn(tmp); // debug
items.push(tmp);


)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(items); // empty



And using readFile() for get .txt's content, con is empty



renderItem(item) 
return (
<View style = styles.renderItemContainer
key=items.indexOf(item) >
<TouchableOpacity style=styles.renderItemTouchableOpacity
onPress = () =>
fileName = item;

var path = RNFS.DocumentDirectoryPath + '/' + fileName;

RNFS.readFile(path, 'utf8')
.then((contents) =>
console.warn(contents);
con = contents; // not working
)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(con); // empty

this.props.navigation.navigate('editorScreen');
>
<Text style = styles.renderItemText>
item
</Text>
</TouchableOpacity>
</View>
);



in render() function, using items array for list .txt files in ScrollView



render() 
return(
....
<ScrollView>

items.map((items) => this.renderItem(items))

</ScrollView>
....
);










share|improve this question







New contributor




Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











If componentWillMount() function is running first time, items array is empty. Why?



componentWillMount() 
items.splice(0, items.length);
RNFS.readDir(RNFS.DocumentDirectoryPath)
.then((result) =>
console.warn('result: ', result); // debug

for(var i = 0; i < result.length; i++)
if(result[i].name.endsWith('.txt'))
var tmp = result[i].name;
console.warn(tmp); // debug
items.push(tmp);


)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(items); // empty



And using readFile() for get .txt's content, con is empty



renderItem(item) 
return (
<View style = styles.renderItemContainer
key=items.indexOf(item) >
<TouchableOpacity style=styles.renderItemTouchableOpacity
onPress = () =>
fileName = item;

var path = RNFS.DocumentDirectoryPath + '/' + fileName;

RNFS.readFile(path, 'utf8')
.then((contents) =>
console.warn(contents);
con = contents; // not working
)
.catch((err) =>
console.log(err.message, err.code);
);

console.warn(con); // empty

this.props.navigation.navigate('editorScreen');
>
<Text style = styles.renderItemText>
item
</Text>
</TouchableOpacity>
</View>
);



in render() function, using items array for list .txt files in ScrollView



render() 
return(
....
<ScrollView>

items.map((items) => this.renderItem(items))

</ScrollView>
....
);







javascript arrays react-native react-native-fs






share|improve this question







New contributor




Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question







New contributor




Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question






New contributor




Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked Nov 9 at 15:13









Onur Güler

14




14




New contributor




Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Onur Güler is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











  • Your console.warn is being executed before your Promise has resolved.
    – Dan
    Nov 9 at 15:14
















  • Your console.warn is being executed before your Promise has resolved.
    – Dan
    Nov 9 at 15:14















Your console.warn is being executed before your Promise has resolved.
– Dan
Nov 9 at 15:14




Your console.warn is being executed before your Promise has resolved.
– Dan
Nov 9 at 15:14












1 Answer
1






active

oldest

votes

















up vote
1
down vote













Try :



componentWillMount() 
items.splice(0, items.length);
RNFS.readDir(RNFS.DocumentDirectoryPath)
.then((result) =>
console.warn('result: ', result); // debug

for(var i = 0; i < result.length; i++)
if(result[i].name.endsWith('.txt'))
var tmp = result[i].name;
console.warn(tmp); // debug
items.push(tmp);



console.warn(items); // empty
)
.catch((err) =>
console.log(err.message, err.code);
);





Your promise runs async => the console.warn is called before the promise resolves (.then(...))






share|improve this answer




















    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );






    Onur Güler is a new contributor. Be nice, and check out our Code of Conduct.









     

    draft saved


    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53228384%2fhow-to-use-react-native-fs%23new-answer', 'question_page');

    );

    Post as a guest






























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    1
    down vote













    Try :



    componentWillMount() 
    items.splice(0, items.length);
    RNFS.readDir(RNFS.DocumentDirectoryPath)
    .then((result) =>
    console.warn('result: ', result); // debug

    for(var i = 0; i < result.length; i++)
    if(result[i].name.endsWith('.txt'))
    var tmp = result[i].name;
    console.warn(tmp); // debug
    items.push(tmp);



    console.warn(items); // empty
    )
    .catch((err) =>
    console.log(err.message, err.code);
    );





    Your promise runs async => the console.warn is called before the promise resolves (.then(...))






    share|improve this answer
























      up vote
      1
      down vote













      Try :



      componentWillMount() 
      items.splice(0, items.length);
      RNFS.readDir(RNFS.DocumentDirectoryPath)
      .then((result) =>
      console.warn('result: ', result); // debug

      for(var i = 0; i < result.length; i++)
      if(result[i].name.endsWith('.txt'))
      var tmp = result[i].name;
      console.warn(tmp); // debug
      items.push(tmp);



      console.warn(items); // empty
      )
      .catch((err) =>
      console.log(err.message, err.code);
      );





      Your promise runs async => the console.warn is called before the promise resolves (.then(...))






      share|improve this answer






















        up vote
        1
        down vote










        up vote
        1
        down vote









        Try :



        componentWillMount() 
        items.splice(0, items.length);
        RNFS.readDir(RNFS.DocumentDirectoryPath)
        .then((result) =>
        console.warn('result: ', result); // debug

        for(var i = 0; i < result.length; i++)
        if(result[i].name.endsWith('.txt'))
        var tmp = result[i].name;
        console.warn(tmp); // debug
        items.push(tmp);



        console.warn(items); // empty
        )
        .catch((err) =>
        console.log(err.message, err.code);
        );





        Your promise runs async => the console.warn is called before the promise resolves (.then(...))






        share|improve this answer












        Try :



        componentWillMount() 
        items.splice(0, items.length);
        RNFS.readDir(RNFS.DocumentDirectoryPath)
        .then((result) =>
        console.warn('result: ', result); // debug

        for(var i = 0; i < result.length; i++)
        if(result[i].name.endsWith('.txt'))
        var tmp = result[i].name;
        console.warn(tmp); // debug
        items.push(tmp);



        console.warn(items); // empty
        )
        .catch((err) =>
        console.log(err.message, err.code);
        );





        Your promise runs async => the console.warn is called before the promise resolves (.then(...))







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 9 at 15:25









        Lumpenstein

        587




        587




















            Onur Güler is a new contributor. Be nice, and check out our Code of Conduct.









             

            draft saved


            draft discarded


















            Onur Güler is a new contributor. Be nice, and check out our Code of Conduct.












            Onur Güler is a new contributor. Be nice, and check out our Code of Conduct.











            Onur Güler is a new contributor. Be nice, and check out our Code of Conduct.













             


            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53228384%2fhow-to-use-react-native-fs%23new-answer', 'question_page');

            );

            Post as a guest














































































            Popular posts from this blog

            Darth Vader #20

            How to how show current date and time by default on contact form 7 in WordPress without taking input from user in datetimepicker

            Ondo