首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

原生js图片上传

原生JavaScript图片上传是指使用纯JavaScript代码实现图片文件从客户端(浏览器)上传到服务器的过程,不依赖任何第三方库或框架。

基础概念

  1. File API:允许网页访问用户计算机上的文件,通过<input type="file">元素选择文件,并通过JavaScript操作这些文件。
  2. XMLHttpRequest/Fetch API:用于与服务器进行通信,发送HTTP请求,实现文件上传。
  3. FormData:一个用于封装表单数据的接口,可以方便地将文件和其他表单数据一起发送到服务器。

优势

  1. 轻量级:不依赖任何外部库,减少页面加载时间。
  2. 灵活性:可以根据需求定制上传逻辑,如图片预览、上传进度显示等。
  3. 兼容性:现代浏览器都支持File API和Fetch API,具有较好的兼容性。

应用场景

  1. 社交媒体:用户头像上传。
  2. 电商网站:商品图片上传。
  3. 在线教育:课程资料图片上传。

实现步骤

  1. 创建一个<input type="file">元素,设置accept属性为image/*以限制只能选择图片文件。
  2. 监听change事件,当用户选择文件后触发。
  3. 使用File API读取文件信息,如文件名、大小、类型等。
  4. 创建一个FormData对象,将文件添加到其中。
  5. 使用Fetch API或XMLHttpRequest发送POST请求,将FormData对象发送到服务器。
  6. 服务器接收文件并保存到指定位置。

示例代码

代码语言:txt
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>图片上传示例</title>
</head>
<body>
    <input type="file" id="fileInput" accept="image/*">
    <button id="uploadBtn">上传图片</button>
    <script>
        document.getElementById('uploadBtn').addEventListener('click', function () {
            var fileInput = document.getElementById('fileInput');
            var file = fileInput.files[0];
            if (!file) {
                alert('请选择一张图片');
                return;
            }
            var formData = new FormData();
            formData.append('file', file);
            fetch('/upload', {
                method: 'POST',
                body: formData
            }).then(function (response) {
                if (response.ok) {
                    alert('图片上传成功');
                } else {
                    alert('图片上传失败');
                }
            }).catch(function (error) {
                console.error('Error:', error);
                alert('图片上传出错');
            });
        });
    </script>
</body>
</html>

注意事项

  1. 服务器端需要处理文件上传请求,保存文件到指定位置,并返回相应的响应。
  2. 为了安全起见,服务器端应对上传的文件进行验证,如检查文件类型、大小等。
  3. 可以使用HTTPS协议加密传输数据,保护用户隐私。
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • js拖拽上传图片

    有时候,在开发中,需要遇到拖拽上传图片的需求,即从磁盘选中一张或多张图片,然后按着鼠标把图片拖动到页面上指定的区域,实现图片的上传。...1、后端上传图片的接口 我是之前用vue写一个简单的后台系统的时候,用Java的SpringMVC+MyBatis的框架写了一个简单的后台管理的一些接口,刚好有一个上传用户头像的接口,该接口是把上传后的图片存储在另外一台...Tomcat下,这里就直接使用这个接口来上传图片。...ie=edge"> Document js...里面用的formData对象来上传图片的,该对象的作用是:   1、用一些键值对来模拟一系列表单控件,即把form中所有表单元素的name与value组装成一个queryString;   2、异步上传二进制文件

    18.2K30

    js批量上传文件_批量上传图片java

    今天说一说js批量上传文件_批量上传图片java,希望能够帮助大家进步!!!...文件上传无疑是web应用中一个非常常用的功能,下面小编给大家分享一下diyUpload.js+ThinkPHP中的UploadFile类实现图片的批量上传。...,可以点击图片上的“X”按钮删除,如下: 页面上js代码如下: 此代码由Java架构师必看网-架构君整理 /* * 服务器地址,成功返回,失败返回参数格式依照jquery.ajax习惯...‘开始上传’按钮上传图片,上传完成后页面展示如下图: 可以修改或者删除图片,也可以点击‘全选图片’按钮,批量删除图片,或者选择多张图片删除: PHP上传图片代码: 此代码由Java..."))); } } } 到此,批量上传图片就全部实现了,但是有一个bug一直困扰了小编很久,就是有些图片原图会成功上传,但缩略图会上传成黑色的图片,如图:

    27.4K40

    js实现本地上传图片预览

    在做网站系统时经常会用到图片上传功能,用户往往希望能看到自己上传的图片的样子,有的人是采用将图片上传到服务器之后再回显到页面,这种方式在无形之中增加了服务器的运行压力,因为如果用户感觉不满意还会再次上传图片...为了减轻服务器压力,我们通过js来实现本地图片上传预览功能,不经过服务器就实现预览效果。...file" name="file" id="doc" style="width:150px;" onchange="javascript:setImagePreview();"> 上面这部分代码是页面上传按钮和显示图片的区域...接下来请看js控制代码 function setImagePreview(avalue) { var docObj=document.getElementById("doc"); var imgObjPreview...imgObjPreview.style.display = 'none'; document.selection.empty(); } return true; } 这样我们就实现了本地图片上传预览功能

    8.1K40
    领券