uniapp APP端一键读写文件并上传文件

1 篇文章 0 订阅
1 篇文章 0 订阅

目录

读写文件

上传文件

完整代码


读写文件

使用的是 HTML5产业联盟提供的方法

通过plus.io可获取文件系统管理对象。

        IO模块管理本地文件系统,用于对文件系统的目录浏览、文件的读取、文件的写入等操作。

IO里面有个方法 

  • requestFileSystem: 请求本地文件系统对象
    • plus.io.requestFileSystem( type, succesCB, errorCB );

参数:

  • type: ( Number ) 必选 本地文件系统常量

    可取plus.io下的常量,如plus.io.PRIVATE_DOC、plus.io.PUBLIC_DOCUMENTS等。

  • succesCB: FileSystemSuccessCallback ) 必选 请求文件系统成功的回调
  • errorCB: FileErrorCallback ) 可选 请求文件系统失败的回调

plus.io.PRIVATE_DOC

plus.io.requestFileSystem(plus.io.PRIVATE_DOC, function(fs) {
          console.error('请求文件系统成功', fs);
        },
        function(err) {
            console.error('请求文件系统失败', err);
        }
);

请求成功返回的fs里面有个属性 root, fs.root是根目录操作对象DirectoryEntry,里面提供了创建打开文件方法 

  • getFile: 创建或打开文件
    • entry.getFile( path, flag, succesCB, errorCB );

参数:

  • path: ( String ) 必选 要操作文件相对于当前目录的地址
  • flag: Flags ) 可选 要操作文件或目录的参数
  • succesCB: FileEntrySuccessCallback ) 可选 创建或打开文件成功的回调函数
  • errorCB: FileErrorCallback ) 可选 创建或打开文件失败的回调函数
 plus.io.requestFileSystem(plus.io.PRIVATE_DOC, function(fs) {
            // 创建文件
            fs.root.getFile('myTxt/1..txt', {
                    create: true
                }, function(fileEntry) {
                    console.error('创建文件成功', fileEntry);
                },
                function(err) {
                    console.error('创建文件失败', err);
                });
        },
        function(err) {
            console.error('请求文件系统失败', err);
        });
}

请求成功返回的 fileEntry 里面有个方法 createWriter

  • createWriter: 获取文件关联的写文件操作对象FileWriter
    • entry.createWriter( succesCB, errorCB );

参数:

plus.io.requestFileSystem(plus.io.PRIVATE_DOC, function(fs) {
            // 创建文件
            fs.root.getFile('myTxt/1..txt', {
                    create: true
                }, function(fileEntry) {
                    // 创建写入流
                    fileEntry.createWriter(function(writer) {
                          console.error('创建写入流成功', writer);
                        },
                        function(err) {
                            console.error('创建写入流失败', err);
                        });
                },
                function(err) {
                    console.error('创建文件失败', err);
                });
        },
        function(err) {
            console.error('请求文件系统失败', err);
        });
}

请求成功返回的 writer 里面有个方法 write代码

  • write: 向文件中写入数据
    • writer.write( data );

参数:

  • data : ( String ) 必选 要写入的数据内容

注意: 如果文件中已经存在数据,新写入的数据将覆盖已有数据。

返回的 writer 里面还有个 onwriteend 回调函数,文件写入操作完成时的回调函数

 plus.io.requestFileSystem(plus.io.PRIVATE_DOC, function(fs) {
            // 创建文件
            fs.root.getFile('myTxt/1..txt', {
                    create: true
                }, function(fileEntry) {
                    // 创建写入流
                    fileEntry.createWriter(function(writer) {
                            // 设置写入内容
                            writer.write('123');
                            // 写入完成回调
                            writer.onwriteend = function(res) {
                                console.log('写入文件成功', res.target.fileName);
                            };
                            // 写入错误回调
                            writer.onerror = function(err) {
                                console.error('写入文件失败', err);
                            };
                        },
                        function(err) {
                            console.error('创建写入流失败', err);
                        });
                },
                function(err) {
                    console.error('创建文件失败', err);
                });
        },
        function(err) {
            console.error('请求文件系统失败', err);
        });

返回的 res.target.fileName,就是操作文件的路径

上传文件

利用uniapp提供的上传方法 uni.uploadFile,也可以利用其它的请求方式比如 Ajax 上传文件,根据返回的 res.target.fileName 文件路径,赋值进去就可以了

const pathUrl = res.target.fileName
if (pathUrl!= '') {
  uni.uploadFile({
      url: '上传地址API',
      filePath: pathUrl,
      name: "file",
      success: (uploadFileRes) => {
              console.log(uploadFileRes, '返回的下载地址');
      },
      complete: () => {
            
      },
  });
}

完整代码

Download() {
    // 请求文件系统
    plus.io.requestFileSystem(plus.io.PRIVATE_DOC, function(fs) {
            // 创建文件
            fs.root.getFile('myTxt/1..txt', {
                    create: true
                }, function(fileEntry) {
                    // 创建写入流
                    fileEntry.createWriter(function(writer) {
                            // 设置写入内容
                            writer.write('123');
                            // 写入完成回调
                            writer.onwriteend = function(res) {
                                console.log('写入文件成功', res.target.fileName);
                                const pathUrl = res.target.fileName

                                if (pathUrl!= '') {
                                    uni.showLoading();
                                    uni.uploadFile({
                                        url: '上传地址API',
                                        filePath: pathUrl,
                                        name: "file",
                                        success: (uploadFileRes) => {
                                            console.log(uploadFileRes, '返回的下载地址');
                                        },
                                        complete: () => {
                                            uni.hideLoading();
                                        },
                                    });
                                }
                            };
                            // 写入错误回调
                            writer.onerror = function(err) {
                                console.error('写入文件失败', err);
                            };
                        },
                        function(err) {
                            console.error('创建写入流失败', err);
                        });
                },
                function(err) {
                    console.error('创建文件失败', err);
                });
        },
        function(err) {
            console.error('请求文件系统失败', err);
        });
}

  • 18
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

joshua king

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值