如何使用 js 读文件

js 读本地文件,必须要依靠 input,如果只有一个文件路径(比如 c:\abc.txt),是无法用 js 读的,这是客户端的安全限制(不能随意读取本地文件)。

所以,js 读文件,首先要有一个 input

<input type="file" id="uploadInp" multiple >

js 代码:

<script>
    var uploadInp = document.querySelector('#uploadInp');
    
    uploadInp.onchange = function () {
        // this.files 是一个 FileList 文件集合
        // 每一项是选择的文件 File
        let file = this.files[0];
        if (!file) return;	// 没选中文件

		// File 中三个重要的属性
        //   name:文件名
        //   size:文件大小
        //   type:文件类型
		
		// 一些常见文件类型的 type 值:
		/*
		pdf: application/pdf
		txt: text/plain
		jpg: image/jpeg
		png: image/png
		xls: application/vnd.ms-excel
		xlsx: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
		doc: application/msword
		docx: application/vnd.openxmlformats-officedocument.wordprocessingml.document
		*/
        
        /* 
        // 判断文件大小
        if (file.size > 1024) {
            alert('上传的文件必须在1KB以内');
            return;
        } */

        /* 
        // 判断文件类型
        if (!/(jpg|jpeg|gif|png)/i.test(file.type)) {
            alert('必须上传PNG/JPG/GIF格式的图片')
            return;
        } */

        // FileReader 文件读取类(异步读取)
        let reader = new FileReader;
        reader.onload = function (ev) {
            // ev.target.result 是读取出来的内容
            // 是 BASE64 格式
            // 格式依赖于函数 readAsDataURL
            abbreImg.src = ev.target.result;
        };
        
        reader.readAsDataURL(file);
        // 还有一些其它读数据的方法
        /*
            + FileReader.readAsDataURL
            + FileReader.readAsArrayBuffer
            + FileReader.readAsText
        */
    };
</script>

参考文档:

  • [input file]https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/Input/file
  • [FileReader]https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值