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,上传,文件


猜你喜欢
创建动态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
