繁体   English   中英

使用 jQuery 和 AJAX 将表单的文件和文本数据上传到 PHP

[英]upload a form's file and text data to PHP using jQuery and AJAX

早上好。 我正在尝试使消息的表单提交更加流畅,避免重新加载页面以发送它。 由于消息可能是文本或图像,我需要将它们都发送到 PHP 页面进行上传。 我在 html 页面中使用此代码:

<form id="newmessage" enctype="multipart/form-data">

<textarea form="newmessage" id="messagetext" name="messagetext" ></textarea>
         
<input type="submit" name="submit" value="send" onclick="return newMessage();">
         
<input type="file" accept="image/*" id="image" name="image">

</form>
      
<script>
function newMessage(){
var messagetext = document.getElementById("messagetext").value;
var image = document.getElementById("image").value;

      $.ajax({
           type:"post",
           url:"new_message.php",
           data: 
           {  
            "messagetext" :messagetext,
            "image" :image,
           },
           cache:false,
           success: function(html) {
               document.getElementById("messagetext").value = "";
                 }
             });
             
             return false;
          }
      </script>

如您所见,我允许用户输入文本区域或上传文件。 当他们提交表单时,调用 newMessage() 方法并将图像和消息文本发送到new_message.php ,后者会处理它们:

   // new_message.php
   $messagetext = $_POST["messagetext"];
   $image = $_FILES["image"]["tmp_name"]; 
   
   if((!empty($messagetext) || isset($image))) {
   
       if(!empty($messagetext)) {
           // create text message
       } else if(isset($image)) {
           // create image message
       }
   }

当我写一条短信时,它工作得很好,但如果它是图像,它就不会发送任何东西。 也许 AJAX 中的图像变量没有正确获取文件。 如果这个问题不清楚,我很抱歉,但我是 StackOverlow 的初学者,我愿意编辑。 感谢所有回复。

你能试试这个吗? 您无需担心 textarea 中的文件和消息。 确保您已添加 jQuery。

$("#newmessage").on("submit", function(ev) {
  ev.preventDefault(); // Prevent browser default submit.

  var formData = new FormData(this);
    
  $.ajax({
    url: "new_message.php",
    type: "POST",
    data: formData,
    success: function (msg) {
      document.getElementById("messagetext").value = "";
    },
    cache: false,
    contentType: false,
    processData: false
  });
  return false;
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM