首页 前端知识 jQuery实现文件上传

jQuery实现文件上传

2024-03-01 12:03:53 前端知识 前端哥 903 925 我要收藏

1、定义UI结构

    <!-- 导入 jQuery -->
<script src="./lib/jquery.js"></script>
    <!-- 文件选择框 -->
    <input type="file" id="file1" />
    <!-- 上传文件按钮 -->
    <button id="btnUpload">上传</button>
复制

2、验证是否选择了文件

$('#btnUpload').on('click'function() {
// 1. 将 jQuery 对象转化为 DOM 对象,并获取选中的文件列表
var files = $('#file1')[0].files
// 2. 判断是否选择了文件
if (files.length <= 0) {
return alert('请选择图片后再上传!‘)
}
})
复制

3、向FormData中追加文件

// 向 FormData 中追加文件
var fd = new FormData()
fd.append('avatar', files[0])
复制

4、使用jQuery发起上传文件的请求

$.ajax({
method'POST',
url'http://www.liulongbin.top:3006/api/upload/avatar',
data: fd,
// 不修改 Content-Type 属性,使用 FormData 默认的 Content-Type 值
contentTypefalse,
// 不对 FormData 中的数据进行 url 编码,而是将 FormData 数据原样发送到服务器
processDatafalse,
successfunction(res) {
console.log(res)
}
})
复制

5、ajaxStart(callback)

        Ajax 请求开始时,执行 ajaxStart 函数。可以在 ajaxStart callback 中显示 loading 效果,示例代码如下:

// 自 jQuery 版本 1.8 起,该方法只能被附加到文档
$(document).ajaxStart(function() {
$('#loading').show()
})
复制

注意: $(document).ajaxStart() 函数会监听当前文档内所有的 Ajax 请求

6、ajaxStop(callback)

        Ajax 请求结束时,执行 ajaxStop 函数。可以在 ajaxStop callback 中隐藏 loading 效果,示例代码如下:

// 自 jQuery 版本 1.8 起,该方法只能被附加到文档
$(document).ajaxStop(function() {
$('#loading').hide()
})
复制

7、完整示例代码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/jquery.js"></script>
</head>
<body>
<input type="file" id="file1" />
<button id="btnUpload">上传文件</button>
<br />
<img src="./images/loading.gif" alt="" style="display: none;" id="loading" />
<script>
$(function () {
// 监听到Ajax请求被发起了
$(document).ajaxStart(function () {
$('#loading').show()
})
// 监听到 Ajax 完成的事件
$(document).ajaxStop(function () {
$('#loading').hide()
})
$('#btnUpload').on('click', function () {
var files = $('#file1')[0].files
if (files.length <= 0) {
return alert('请选择文件后再上传!')
}
var fd = new FormData()
fd.append('avatar', files[0])
// 发起 jQuery 的 Ajax 请求,上传文件
$.ajax({
method: 'POST',
url: 'http://www.liulongbin.top:3006/api/upload/avatar',
data: fd,
// --------
processData: false,
contentType: false,
// -------- 只要是上传文件这两个属性值,一定要设置为false,这是固定写法
success: function (res) {
console.log(res)
}
})
})
})
</script>
</body>
</html>
复制
转载请注明出处或者链接地址:https://www.qianduange.cn//article/3037.html
标签
评论
还可以输入200
共0条数据,当前/页
发布的文章

如何定义 jQuery 函数?

2024-03-20 11:03:16

jQuery事件方法

2024-03-20 11:03:06

JQuery前端操作JSON浅谈

2024-03-12 01:03:20

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!