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

首頁(yè) > 開發(fā) > JS > 正文

react-native-fs實(shí)現(xiàn)文件下載、文本存儲(chǔ)的示例代碼

2024-05-06 16:39:56
字體:
供稿:網(wǎng)友

本文內(nèi)容:

react-native-fs的簡(jiǎn)單使用

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

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

另外還有一個(gè)下載的庫(kù) :https://github.com/wkh237/react-native-fetch-blob

安裝步驟

第一步:

npm install react-native-fs --save

第二步:

react-native link react-native-fs

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

簡(jiǎn)單使用

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文件內(nèi)容

/*讀取txt文件內(nèi)容*/  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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到JavaScript/Ajax教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 潜山县| 房产| 江西省| 鄄城县| 隆昌县| 夏邑县| 泾阳县| 鹤山市| 运城市| 襄垣县| 信宜市| 潮州市| 双流县| 美姑县| 大埔区| 筠连县| 临汾市| 盐山县| 台前县| 新晃| 柘荣县| 临安市| 额尔古纳市| 汝城县| 内江市| 广元市| 安龙县| 武胜县| 龙山县| 扬州市| 淮阳县| 苏尼特右旗| 漠河县| 于都县| 土默特右旗| 平泉县| 靖安县| 兴文县| 汤阴县| 通城县| 陆丰市|