读取本地文件夹以及读取文件的内容

一. 读取本地文件夹以及子文件

	const fileBtn = document.querySelector('#file') // 按钮
fileBtn.onclick = async function () {
    try {
        const handler = await showDirectoryPicker() // 打开本地文件夹的api 返回 promise
        const files = await handlerPicker(handler) 
        // readyFile(files)
    } catch (e) {
        console.log('取消')
        console.error(new Error(e))
    }
}
async function handlerPicker(handler) {
    if (handler.kind === 'file') return handler // 文件
    handler.files = [] // 收集文件
    const iter = handler.entries() // 文件夹的子文件
    for await (const item of iter) { // 使用递归的方式分别拿出文件夹的 子文件
        handler.files.push(await handlerPicker(item[1])) // 存储到 容器里面
    }
    return handler
}

二. 读取文件的内容

	async function readyFile(file) {
		const _file = await file.getFile()
     	const reader = new FileReader()
     	reader.readAsText(_file, 'utf-8') // 参数一为 文件对象, 参数二为 读取文件以什么编码读取
        reader.onload = e => {
			console.log(e);
			console.log(e.target.result) // 文件的内容
		}
	}
  • 12
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值