news 2026/6/21 22:18:28

ajax的基本使用(上传文件)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ajax的基本使用(上传文件)

index.html

<html> <head> <title>js</title> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> </head> <body> <div> 我是显示内容 </div> <div> <input type="file" name="myFile" class="file_class"/> <button class="ajax_btn">原生ajax</button> </div> </body> <script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script> <script type="text/javascript" src="./index.js"> </script> </html>

index.js

$(function(){ $(".ajax_btn").click(function(){ var xhr = new XMLHttpRequest(); xhr.open("post","http://localhost",true); xhr.onreadystatechange = function(e) { if(xhr.readyState == 4 && xhr.status == 200) { console.log(JSON.parse(xhr.responseText)); } } var file = $(".file_class")[0].files[0]; var fd = new FormData(); fd.append("info","zlx"); fd.append("fileInfo",file); xhr.send(fd); }); })

index.php

<?php if($_FILES['fileInfo']) { move_uploaded_file($_FILES['fileInfo']['tmp_name'],"./".$_FILES['fileInfo']['name']); } $result = array("code"=>200,"msg"=>$_POST["info"]."上传了图片"); print_r(json_encode($result)); ?>

注:

ajax使用FormData对象时,不用再去设置表头Content-type,FormData可以用js来实现form表单上传的对象,通过append来添加传递给后台的值,如,我们这里传了info,值为 zlx,fileInfo,值为一个文件对象,$(".file_class")[0].files[0]用来获取file对象,就是我们选择的文件,需要在PHP中使用$_FILES['fileInfo']来获取。

通过浏览器调试模式看到请求头,

这个fileInfo是一个二进制的文件。

通过move_uploaded_file来把上传来的缓存文件放到我们希望保存的地方。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/13 13:29:42

自定义控件在screen中的封装实践

在screen中玩转自定义控件&#xff1a;打造嵌入式系统的轻量级交互界面你有没有遇到过这样的场景&#xff1f;一台部署在工厂角落的工业网关&#xff0c;没有图形界面&#xff0c;只能通过串口或 SSH 登录调试。你想查看设备启动进度、网络状态、CPU 负载&#xff0c;却发现日志…

作者头像 李华
网站建设 2026/6/20 0:48:53

VDMA驱动开发:手把手教程(从零实现)

VDMA驱动开发实战&#xff1a;从零构建高效视频传输系统你有没有遇到过这样的场景&#xff1f;在Zynq平台上接了一个高清摄像头&#xff0c;结果CPU一跑图像采集就飙到90%以上&#xff0c;帧率还上不去——画面卡顿、丢帧严重。问题出在哪&#xff1f;很可能就是你在“用CPU搬砖…

作者头像 李华
网站建设 2026/6/17 20:06:01

AMD Ryzen处理器调试实战:SMU工具从入门到精通

AMD Ryzen处理器调试实战&#xff1a;SMU工具从入门到精通 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://gitcode.c…

作者头像 李华
网站建设 2026/6/21 7:28:57

城通网盘直连解析:3分钟掌握免限速下载核心技术

城通网盘直连解析&#xff1a;3分钟掌握免限速下载核心技术 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 还在为城通网盘缓慢的下载速度而困扰吗&#xff1f;想要彻底摆脱限速束缚&#xff0c;实现真…

作者头像 李华
网站建设 2026/6/19 14:20:08

PPTTimer完整使用教程:从安装到精通的时间管理神器

PPTTimer完整使用教程&#xff1a;从安装到精通的时间管理神器 【免费下载链接】ppttimer 一个简易的 PPT 计时器 项目地址: https://gitcode.com/gh_mirrors/pp/ppttimer 在当今快节奏的演示环境中&#xff0c;时间掌控能力直接影响演讲效果。PPTTimer作为一款基于Auto…

作者头像 李华