H5 File 对象获取 Input type=file 文件详细信息

目录

H5 File 对象概述

编码示例

accept 属性过滤文件类型


需求分析

1、假如现在需要获取用户上传文件的详细信息,如 文件名称、文件大小、文件类型、上传修改时间等等。

H5 File 对象概述

1、文件上传表单如下所示:method 必须是 post、enctype 必须是 multipart/form-data 类型、如果是多文件上传,则在 type=file 中加上 multiple 属性。

2、需要知道的是:“每一个 type=file 的 input 都是一个 File 对象数组 ”。(注意 File 是 DOM 对象)

<form method="post" enctype="multipart/form-data">
    单文件上传:<input type="file" id="fileUp">
</form>

<form method="post" enctype="multipart/form-data">
    多文件上传:<input type="file" id="fileUps" multiple>
</form>

3、File 对象从控制台输出的效果如下:

lastModified :最后一次修改时间(毫秒数)
lastModifiedDate : 最后一次修改日期
name :文件名
type :文件类型(需要注意的是,它并不能完全识别出所有文件类型)
size :文件大小  ,单位 字节。

编码示例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
    <title></title>
    <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>

    <script type="text/javascript">
        $(function () {
            //单文件上传
            $("#fileUp").on("change", function () {
                //$(this)[0] 等价于 $(this).get(0),将 JQuery 对象转为 DOM 对象,files 为其属性,得到的是一个文件对象数组
                var files = $(this)[0].files;
                if(files.length>0){//未选中文件时,长度为0
                    var file = files[0];//因为是单文件上传,所以只有一个文件(File)对象
                    console.log(file);//下面所有的属性都可以从此对象的输出得到
                    console.log("文件名称:" + file.name + ",文件大小:" + file.size + "字节,文件类型:"
                        + file.type + ",上次修改时间:" + file.lastModifiedDate);
                }
            });

            //多文件上传
            $("#fileUps").on("change", function () {
                //$(this)[0] 等价于 $(this).get(0),将 JQuery 对象转为 DOM 对象,files 为其属性,得到的是一个文件数组
                var files = $(this).get(0).files;
                for (var i = 0; i < files.length; i++) {
                    console.log((i + 1) + ":文件名称:" + files[i].name + ",文件大小:" + files[i].size + "字节,文件类型:"
                            + files[i].type + ",上次修改时间:" + files[i].lastModifiedDate);
                }
            });
        });
    </script>
</head>
<body>
<form method="post" enctype="multipart/form-data">
    单文件上传:<input type="file" id="fileUp">
</form>

<form method="post" enctype="multipart/form-data">
    多文件上传:<input type="file" id="fileUps" multiple>
</form>

</body>
</html>

accept 属性过滤文件类型

1、accept 属性仅适用于 <input type="file">,它规定了可通过文件上传提交的文件类型。

2、提示:请不要将该属性作为您唯一的验证工具,应该在服务器上对文件上传进行验证。

3、语法:<input accept="value">,value 是一个或多个文件格式,多个时用 "," 隔开,如 ".png,.jpg,.gif",不区分大小写。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
    <title></title>
    <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
</head>
<body>
<form method="post" enctype="multipart/form-data" action="#">
    <!-- 只允许上传 .png、gif、jpg、jpeg 格式的文件,不区分大小写-->
    单文件上传: <input type="file" name="pic" accept=".gif,.jpg,.png,.jpeg"/>
    <button type="submit">上传</button>
</form>
</body>
</html>

 

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 Windows 下使用 C++ 编程语言,如果需要使用 HDF5 库中的 H5::H5File 类,则需要完成以下步骤: 1. 下载并安装 HDF5 库:可以从 HDF Group 的官方网站(https://www.hdfgroup.org/downloads/hdf5/)下载 HDF5 库的 Windows 版本,然后按照安装向导完成安装过程。 2. 配置编译器环境:在 C++ 项目中,需要将 HDF5 库的头文件路径和库文件路径添加到编译器的搜索路径中。在 Visual Studio 等集成开发环境中,可以通过以下方式完成配置: - 在项目属性中设置 C/C++ 编译器的附加包含目录,将 HDF5 库的 include 目录添加到列表中; - 在项目属性中设置链接器的附加库目录,将 HDF5 库的 lib 目录添加到列表中; - 在项目属性中设置链接器的附加依赖项,将需要使用的 HDF5 库的名称添加到列表中,例如:hdf5_cpp.lib。 3. 在代码中包含头文件:在需要使用 H5::H5File 类的源文件中,需要包含 HDF5 库的头文件,例如: ```c++ #include <H5Cpp.h> ``` 4. 创建 H5::H5File 对象:使用 H5::H5File 类的构造函数可以创建一个 HDF5 文件对象,例如: ```c++ H5::H5File file("test.h5", H5F_ACC_TRUNC); ``` 这样就创建了一个名为 “test.h5” 的 HDF5 文件,并且设置了文件的访问权限为 H5F_ACC_TRUNC,即如果文件已经存在,则会被截断清空。 以上就是在 Windows 下使用 C++ 编程语言,使用 HDF5 库中的 H5::H5File 类的基本步骤。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

蚩尤后裔-汪茂雄

芝兰生于深林,不以无人而不芳。

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

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

打赏作者

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

抵扣说明:

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

余额充值