国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

react-native-fs實現文件下載、文本存儲的示例代碼

2019-11-19 15:19:40
字體:
來源:轉載
供稿:網友

本文內容:

react-native-fs的簡單使用

  1. 下載文件(圖片、文件、視頻、音頻)
  2. 將文本寫入本地 txt
  3. 讀取txt文件內容
  4. 在已有的txt上添加新的文本
  5. 刪除文件
  6. 上傳文件 only iOS

github鏈接: https://github.com/itinance/react-native-fs

另外還有一個下載的庫 :https://github.com/wkh237/react-native-fetch-blob

安裝步驟

第一步:

npm install react-native-fs --save

第二步:

react-native link react-native-fs

OK 即可開始使用(不放心的可以按照github上的對比一下)

簡單使用

import RNFS from 'react-native-fs';

下載文件

/*下載文件*/  downloadFile() {    // On Android, use "RNFS.DocumentDirectoryPath" (MainBundlePath is not defined)    // 圖片    // const downloadDest = `${RNFS.MainBundlePath}/${((Math.random() * 1000) | 0)}.jpg`;    // const formUrl = 'http://img.kaiyanapp.com/c7b46c492261a7c19fa880802afe93b3.png?imageMogr2/quality/60/format/jpg';    // 文件    // const downloadDest = `${RNFS.MainBundlePath}/${((Math.random() * 1000) | 0)}.zip`;    // const formUrl = 'http://files.cnblogs.com/zhuqil/UIWebViewDemo.zip';    // 視頻    // const downloadDest = `${RNFS.MainBundlePath}/${((Math.random() * 1000) | 0)}.mp4`;    // http://gslb.miaopai.com/stream/SnY~bbkqbi2uLEBMXHxGqnNKqyiG9ub8.mp4?vend=miaopai&    // https://gslb.miaopai.com/stream/BNaEYOL-tEwSrAiYBnPDR03dDlFavoWD.mp4?vend=miaopai&    // const formUrl = 'https://gslb.miaopai.com/stream/9Q5ADAp2v5NHtQIeQT7t461VkNPxvC2T.mp4?vend=miaopai&';    // 音頻    const downloadDest = `${RNFS.MainBundlePath}/${((Math.random() * 1000) | 0)}.mp3`;    // http://wvoice.spriteapp.cn/voice/2015/0902/55e6fc6e4f7b9.mp3    const formUrl = 'http://wvoice.spriteapp.cn/voice/2015/0818/55d2248309b09.mp3';    const options = {      fromUrl: formUrl,      toFile: downloadDest,      background: true,      begin: (res) => {        console.log('begin', res);        console.log('contentLength:', res.contentLength / 1024 / 1024, 'M');      },      progress: (res) => {        let pro = res.bytesWritten / res.contentLength;        this.setState({          progressNum: pro,        });      }    };    try {      const ret = RNFS.downloadFile(options);      ret.promise.then(res => {        console.log('success', res);        console.log('file://' + downloadDest)      }).catch(err => {        console.log('err', err);      });    }    catch (e) {      console.log(error);    }  }

將文本寫入本地 txt

 /*將文本寫入本地 txt*/  writeFile() {    // create a path you want to write to    const path = RNFS.MainBundlePath + '/test.txt';    // write the file    RNFS.writeFile(path, '這是一段文本,YES', 'utf8')      .then((success) => {        console.log('path', path);      })      .catch((err) => {        console.log(err.message);      });  }

讀取txt文件內容

/*讀取txt文件內容*/  readFile() {    // create a path you want to delete    const path = RNFS.MainBundlePath + '/test.txt';    return RNFS.readFile(path)      .then((result) => {        console.log(result);        this.setState({          readTxtResult: result,        })      })      .catch((err) => {        console.log(err.message);      });  }

在已有的txt上添加新的文本

/*在已有的txt上添加新的文本*/  appendFile() {    const path = RNFS.MainBundlePath + '/test.txt';    return RNFS.appendFile(path, '新添加的文本', 'utf8')      .then((success) => {        console.log('success');      })      .catch((err) => {        console.log(err.message);      });  }

刪除文件

  /*刪除文件*/  deleteFile() {    // create a path you want to delete    const path = RNFS.MainBundlePath + '/test.txt';    return RNFS.unlink(path)      .then(() => {        console.log('FILE DELETED');      })      // `unlink` will throw an error, if the item to unlink does not exist      .catch((err) => {        console.log(err.message);      });  }

上傳文件 only iOS

 /*上傳文件 only iOS*/  uploadFile() {    const uploadSrc = `${RNFS.MainBundlePath}/test.txt`;    const uploadUrl = 'http://buz.co/rnfs/upload-tester.php';    const options = {      toUrl: uploadUrl,      files: [{name: 'myfile', filename: 'test.txt', filepath: uploadSrc, filetype: 'text/plain'}],      background: true,      method: 'POST', // PUT      begin: (res) => {        console.log('begin', res);      },      progress: (res) => {        console.log('progress', res);      }    };    const ret = RNFS.uploadFiles(options);    return ret.promise.then(res => {      const response = JSON.parse(res.body);      console.log(response);    })      .catch(err => {        console.log('err', err);      });  }

demo:https://github.com/chjwrr/RN-react-native-fs

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄂伦春自治旗| 盐山县| 象州县| 衢州市| 冕宁县| 大方县| 青铜峡市| 新密市| 密云县| 资溪县| 长寿区| 尼玛县| 古浪县| 兰西县| 桃园市| 甘德县| 塔城市| 德清县| 岳西县| 嘉鱼县| 阳曲县| 苍溪县| 静安区| 灵台县| 嘉义市| 武冈市| 桦川县| 皮山县| 尼勒克县| 杭锦旗| 唐海县| 任丘市| 永宁县| 丹棱县| 汪清县| 青海省| 辽阳市| 鸡西市| 蒙阴县| 高安市| 永嘉县|