簡體   English   中英

php-將數組從php傳遞到jquery ajax,然后再次將相同的數組從jquery傳遞到php

[英]php - pass an array from php to jquery ajax and then again pass the same array from jquery to php

我處於一種情況,我正在使用json_encode將數組從php傳遞到jquery ajax,並將其保存在我在jquery腳本var myarr = []中聲明的空數組中,然后在同一腳本中我發送相同的數組,即,通過$ .ajax使用JSON.stringify函數通過$ .ajax將php腳本發送給php腳本,並在php腳本中接收數組,例如json_decode($ _ POST ['myarr'],true),但問題是它沒有轉換回數組。 我想接收一個數組,以便可以使用foreach循環讀取該數組。

這是下面的代碼。 首先,我在jQuery腳本中聲明一個數組

var imgArr = [];

然后從php腳本中獲取所有圖像,並將其保存在上述聲明的數組中

PHP Script:

$getProfileId = $users->getPrfId($photoId);
$getImages = array();
$getImages = $users->getTypeImage($getProfileId);
//echo json_encode($getImages);
foreach($getImages as $value){
   echo json_encode($value);
 }

JQuery
  $.ajax({
        type: 'POST',
        url: 'fetchAllImages.php',
        data: {'photoId': photoId},
        success: function(data){
             imgArr = data;
          }
        });

現在,在其他按鈕的同一腳本中,單擊“我使用$ .ajax將此數組imgArr發送到php腳本”。 這是代碼:

JQuery:

$('#right_arrow').live('click', function(e){

var photoId =   $(this).siblings('#o_popup_post').children('#o_post_box').children("#o_complete_post_image").children("img").attr("id");
       $.ajax({
       type: 'POST',
       url: 'nextImage.php',
       data: {'photoId': photoId, 'imgArr' : JSON.stringify(imgArr)},
               beforeSend: function(){
                $('#o_popup_post').fadeOut("normal").remove();
                    $('.o_background_popup').append("<div id='o_popup_post'></div>");
       },
       success: function(response){
            $('#o_popup_post').append(response);
        // alert(imgArr);

       }
    });
   });  


  PHP Script:

  $photoId = $_POST['photoId'];

  $imageArray = array();
  $imageArray = json_decode($_POST['imgArr'], true);

  foreach($imageArray as $key=>$value){....}

請幫忙。 謝謝

我在網絡服務器上嘗試了您的示例...按預期工作...並且正確...我刪除的唯一一件事是beforeSend和成功的javascript函數實現

我測試了一下,它可以正常工作

HTML:test.html

    <html>
    <head>
    <script type="text/javascript" src="//code.jquery.com/jquery-2.1.3.min.js">
    </script>
    </head>
    <body>
    <button id="btn">btn</button>
    <script type="text/javascript">
    $(function() {
    $('#btn').on('click', function(evt) {
       var photoId = 1;
       var imgArr = [{ "name": "photo.jpg", "id": 1 }];
       $.ajax({
              type: 'POST',
                 url: 'test.php',
                 data: {'photoId': photoId, 'imgArr' : JSON.stringify(imgArr)},
                 beforeSend: function(){
                 },
                 success: function(response){
                     alert(imgArr);
                }
            });
    });
    });
    </script>
    </body>
    </html>

PHP:test.php

    <?php
    //print_r($_POST);

    $photoId = $_POST['photoId'];

    $imageArray = array();
    $imageArray = json_decode($_POST['imgArr'], true);

    print_r($imageArray);

    foreach($imageArray as $key=>$value){

    }
    ?>

$ imageArray變量是一個數組數組,如print_r($ imageArray)輸出所示:

    Array
    (
        [0] => Array
            (
                [name] => photo.jpg
                [id] => 1
            )

    )

因此,您必須像這樣行走:

    foreach($imageArray as $key=>$value){
        echo $value["name"];
    }

或者您可以嘗試使用此函數,該函數根據PHP中的魔術引號設置來處理JSON中的斜杠問題:

    function _json_decode($string) {
        if (get_magic_quotes_gpc()) {
            $string = stripslashes($string);
        }

        return json_decode($string);
    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM