js 上传文件预览的简单实例

作者:jingxian 时间:2024-06-05 09:11:59 

1. FILE API

html5提供了FIle和FileReader两个方法,可以读取文件信息并读取文件。

2. example


<html>
<body>
<div id="test-image-preview"
style="border: 1px solid rgb(204, 204, 204); width: 100%; height: 200px; background-size: contain; background-repeat: no-repeat; background-position: center center;"> </div>
<br/>
<div id="test-file-info"></div>
<br/>
<input type="file" id="test-image-file">
<script type="text/javascript">

var
 fileInput = document.getElementById('test-image-file'),
 info = document.getElementById('test-file-info'),
 preview = document.getElementById('test-image-preview');
// 监听change事件:
fileInput.addEventListener('change', function () {
 // 清除背景图片:
 preview.style.backgroundImage = '';
 // 检查文件是否选择:
 if (!fileInput.value) {
   info.innerHTML = '没有选择文件';
   return;
 }
 // 获取File引用:
 var file = fileInput.files[0];
 // 获取File信息:
 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; // '...(base64编码)...'      
   preview.style.backgroundImage = 'url(' + data + ')';
 };
 // 以DataURL的形式读取文件:
 reader.readAsDataURL(file);
});
</script>

</body>
</html>

以DataURL的形式读取到的文件是一个字符串,类似于...(base64编码)...,

常用于设置图像。如果需要服务器端处理,把字符串base64,后面的字符发送给服务器并用Base64解码就可以得到原始文件的二进制内容。

3. 解释

上面的代码还演示了JavaScript的一个重要的特性就是单线程执行模式。在JavaScript中,浏览器的JavaScript执行引擎在执行JavaScript代码时,总是以单线程模式执行,也就是说,任何时候,JavaScript代码都不可能同时有多于1个线程在执行。

你可能会问,单线程模式执行的JavaScript,如何处理多任务?

在JavaScript中,执行多任务实际上都是异步调用,比如上面的代码:

reader.readAsDataURL(file);

就会发起一个异步操作来读取文件内容。因为是异步操作,所以我们在JavaScript代码中就不知道什么时候操作结束,因此需要先设置一个回调函数:


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

当文件读取完成后,JavaScript引擎将自动调用我们设置的回调函数。执行回调函数时,文件已经读取完毕,所以我们可以在回调函数内部安全地获得文件内容。

标签:js,上传,文件
0
投稿

猜你喜欢

  • 创建动态MSSQL数据库表

    2024-01-19 03:04:08
  • 一文教你如何快速学会Go的struct数据类型

    2024-02-14 22:58:44
  • 在Pycharm中修改文件默认打开方式的方法

    2023-03-12 06:34:23
  • matplotlib之pyplot模块坐标轴标签设置使用(xlabel()、ylabel())

    2021-10-16 11:01:10
  • MySQL慢查询日志的配置与使用教程

    2024-01-16 08:57:21
  • 如何正确使用开源项目?

    2023-01-29 22:14:57
  • Python多进程同步简单实现代码

    2021-05-17 23:48:04
  • MySQL自定义函数和存储过程示例详解

    2024-01-27 15:25:02
  • python批量解压zip文件的方法

    2022-08-26 16:20:00
  • 利用golang的字符串解决leetcode翻转字符串里的单词

    2023-07-17 16:36:21
  • python实现杨氏矩阵查找

    2021-09-28 15:03:26
  • python中使用pyhook实现键盘监控的例子

    2023-08-17 10:21:52
  • js 将json字符串转换为json对象的方法解析

    2023-07-22 21:41:49
  • Python的形参和实参使用方式

    2021-10-02 22:08:07
  • Asp中Server.ScriptTimeOut脚本超时属性需要注意的一点

    2008-10-18 14:53:00
  • python简单读取大文件的方法

    2021-04-24 04:10:47
  • PyCharm如何设置Console控制台输出自动换行

    2022-05-22 03:42:18
  • Python爬虫采集微博视频数据

    2023-08-11 16:01:03
  • linux下python使用sendmail发送邮件

    2023-02-27 00:14:33
  • Win10下安装CUDA11.0+CUDNN8.0+tensorflow-gpu2.4.1+pytorch1.7.0+paddlepaddle-gpu2.0.0

    2022-05-08 19:29:32
  • asp之家 网络编程 m.aspxhome.com