dongmen1860 2016-10-30 05:43
浏览 8
已采纳

使用jquery和ajax将所选文件发送到另一个页面

I have 2 textboxes and 2 radio buttons.

I can send their values to page insert.php

I added a file input. but I can't send its selected file to page insert.php

How can I do it?

My file input tag's id is file-image.

********************************************** page index.php

$("#btn-save").click(function(){
    $.post("insert.php",
        {
            title_fa: $("#txt-title-fa").val().trim(),
            title_en: $("#txt-title-en").val().trim(),
            title_visible: $('input[name=radio-visible]:checked').val(),
            title_language: $('input[name=radio-language]:checked').val()
        },
            function(data,status){
                if(status === "success")
                    {
                        alert("success");
                    }                                                
            });
});

********************************************** page insert.php

<?php      
    $title_fa = $_POST['title_fa'];
    $title_en = $_POST['title_en'];
    $title_visible = $_POST['title_visible'];
    $title_language = $_POST['title_language'];
?>
  • 写回答

1条回答 默认 最新

  • dsaaqdz6223 2016-10-30 07:14
    关注

    I have used the below code may times, here is a way to send your form data and files :

    $("#btn-save").click(function(){
            var fd = new FormData();
            var file_data = $('input[name^="your_file_input_name"]')[0].files; 
            for(var i = 0;i<file_data.length;i++){
                fd.append("file_"+i, file_data[i]);
            }
            var  other_data = $("#your_form_id_here").serializeArray();
             $.each(other_data,function(key,input){
                fd.append(input.name,input.value);
            });
    
            $.ajax({
            url : 'insert.php',
            type : "post",
            data : fd,
            cache: false,
            contentType: false,
            processData: false,
            success : function(data){
                    console.log(data); //server response
    
            }
        });
        });
    

    on server side, you will receive your file in $_FILES['file_0'] and other data in $_POST array

    Hope it helps !

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 不同尺寸货物如何寻找合适的包装箱型谱
  • ¥15 求解 yolo算法问题
  • ¥15 虚拟机打包apk出现错误
  • ¥15 用visual studi code完成html页面
  • ¥15 聚类分析或者python进行数据分析
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝