JavaScript学习笔记之操作文件(第五天)

文件操作具体指的是文件上传,通常在表单中采用

 <input type="file" id="test-file-upload">

来上传文件。表单form要做一些设置

<form id="form1" enctype="multipart/form-data" method="post">
    <input type="file" id="test-file-upload">
</form>

enctype必须为multipart/form-data,目的是浏览器的正确编码,提交方法为post。

提交的文件处理一般都是后台来处理,而js则是处理对文件的校验。

例如:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>操作文件</title>
</head>
<body>

<form id="form1" enctype="multipart/form-data" method="post">
    <input type="file" id="test-file-upload">
</form>
<br>
<button type="submit" onclick="aa()">submit</button>
<script>
    function aa() {
        var f=document.getElementById('test-file-upload');
        var filename=f.value;
        if (!filename || !(filename.endsWith('.jpg') || filename.endsWith('.png') || filename.endsWith('.gif'))) {
            alert('Can only upload image file.');
            return false;
        }else {
            alert(' upload image file success');
        }
    }
    String.prototype.endsWith=function(str){
        if(str==null||str==""||this.length==0||str.length>this.length)
            return false;
        if(this.substring(this.length-str.length)==str)
            return true;
        else
            return false;
        return true;
    }

    String.prototype.startWith = function(str){
        if(str == null || str== "" || this.length== 0 || str.length > this.length){
            return false;
        }
        if(this.substr(0,str.length) == str){
            return true;
        }else{
            return false;
        }
        return true;
    };
</script>
</body>
</html>

上传一张图片,需要验证图片的格式,js没有提供endwith方法,故而需要自己封装一个endwith方法。


获取上传文件信息,对读取文件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>读取上传的文件</title>
</head>
<body>
 <form>
     <input type="file" id="test_upload_file" onchange="upload_file()">
 </form>
<br>
<!--<button type="submit" onclick="upload_file()">Submit</button>-->
<p id="test-file-info"></p>
<br>
 <div id="test-image-preview" style="width:  200px;height: 200px">
 </div>
</body>
<script>
    function upload_file() {
        var
            fileInput=document.getElementById('test_upload_file');
            var info=document.getElementById('test-file-info');
            var preview=document.getElementById('test-image-preview');

            fileInput.addEventListener('change',function () {
                preview.style.backgroundImage='';

                if(!fileInput.value){
                    info.innerHTML='没有选择文件';
                    return;
                }
                var file=fileInput.files[0];
                info.innerHTML='文件'+file.name+'<br>'+
                               '大小'+file.size+'<br>'+
                               '修改'+file.lastModifiedDate;
                if(file.type!=='image/jpeg'&&file.type!=='image/png'&&file.type!=='image/gif'){
                    alert('上传的不是有效图片');
                    return;
                }

                var reader=new FileReader();
                reader.onload=function (e) {
                    var data=e.target.result;
                    preview.style.backgroundImage='url('+data+')';
                }
                reader.readAsDataURL(file);
            });

    }
</script>
</html>

这里创建一个表单,上传文件,创建一个p标签打印文件信息,创建一个div显示上传图片。

这里upload_file方法需要在onchange监听里面回调,监听上传控件,清除div背景,如果值为空,则为上传文件,获取文件上传列表的第一个文件,打印文件名称大小修改日期等属性,并判断文件类型。

通过filereader来获取文件,js通过单线程来执行,获取图片必须要异步进行, 所以调用了reader.readAsDataURL(file);来异步执行。

但是我们不知道何时执行结束来获取图片,所以需要回调监听

reader.onload = function(e) {
    // 当文件读取完成后,自动调用此函数:
};

在里面获取并展示图片。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值