iframe を非表示にして更新せずにファイルをアップロードする まず、ajax ではファイルをアップロードできないため、しばらく誤解されましたが、今夜は眠れなかったので、指示に従って更新せずにファイルをアップロードしました 。 >実際、原理は非常に単純です。 シンプル 一般的な タグと比較すると、ターゲット属性が 1 つだけあります。タブ ページを開いてデータを送信する場所を指定します。 この属性が設定されていない場合、アクション内の URL はリダイレクトされ、通常どおりこのページで開かれます。 そして、iframe の name 値、つまり「upload」に設定すると、CSS が非表示に設定されているため、iframe で開かれます。 display:none を削除すると、サーバーから返された情報も表示されます。 あなたが主催したクラスも投稿してください。 class upload{ public $_file; public function __construct( $name =null) { if(is_null($name) || !isset($_FILES[$name])) $name = key($_FILES); if(!isset($_FILES[$name])) throw new Exception("并没有文件上传"); $this->_file = $_FILES[$name]; if(!is_uploaded_file($this->_file['tmp_name'])) throw new Exception("异常情况"); if($this->_file['error'] !== 0) throw new Exception("错误代码:".$this->_file['error']); } public function moveTo( $new_dir) { $real_dir = $this->checkDir($new_dir); return move_uploaded_file($this->_file['tmp_name'], $real_dir.'/'.$this->_file['name']); } private function checkDir($dir) { $real_dir = realpath($dir); if($real_dir === false) throw new Exception("给定目录{$dir}不存在"); if(!is_writable($real_dir)) throw new Exception("给定目录{$dir}不可写"); return $real_dir; } } 呼び出し例: $inputName = 'uploadfile'; // 即 中的name值,不填也行$upload = new upload($inputName);$new_dir = "/www"; // 将文件移动到的路径$upload->moveTo($new_dir);