2017-07-31 14 views
0

AXIOS.Itsを使用してデータを取得するAjaxリクエストのような単純なHTTP POSTリクエストを試しています。ここにHTMLがあります。それはgetData.phpにpostリクエストを送信します。JSON forループスルー配列は最後の値のみを表示します

getData.php

<?php 
$servername = "localhost"; 
$username = "root"; 
$password = ""; 

// Create connection 
$conn = mysqli_connect($servername, $username, $password,"db_test"); 


$sql = "SELECT * FROM user"; 
$result = $conn->query($sql); 
$resultArray = array(); 
if ($result->num_rows > 0) { 

    while($row = $result->fetch_assoc()) { 
     $resultArray[] = $row; 

    } 

    echo json_encode($resultArray); 
    return; 

} else { 
    echo "0 results"; 
} 
$conn->close(); 

?> 

<!doctype html> 
<html> 
<head> 
    <title>axios - post example</title> 
    <link rel="stylesheet" type="text/css" href="//maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css"/> 
</head> 
<body class="container"> 
<h1>Axios.post</h1> 

<form role="form" class="form" onsubmit="return false;"> 
    <div class="form-group"> 
     <label for="data">Output</label> 
     <textarea id="data" class="form-control container" rows="5"></textarea> 
    </div> 
    <button id="post" type="button" class="btn btn-primary">POST</button> 
</form> 

<!--<div id="output" class=""></div>--> 

<script src="https://unpkg.com/axios/dist/axios.min.js"></script> 
<script> 
    (function() { 

     document.getElementById('post').onclick = function() { 
      var output = document.getElementById('data'); 
      axios.post('getData.php') 
       .then(function (res) { 


        // console.log(res.data); 
        output.className = 'container'; 
         for (i = 0; i < res.data.length; i++) { 
         output.innerHTML = res.data[i].id + "\n" + res.data[i].name; 

        } 

       }) 
       .catch(function (err) { 
        output.className = 'container text-danger'; 
        output.innerHTML = err.message; 
       }); 
     }; 
    })(); 
</script> 
</body> 
</html>` 

しかし、私はそれが唯一の最後のrow.Itがテーブルからデータを取得し、配列を作成して返す配列をループのためにしようとしています。 forループで何が間違っていますか?

+0

、 'output.innerHTML =' GOODがoutput.innerHTML + = ' – RiggsFolly

答えて

0

output.innerHTML = res.data[i].id + "\n" + res.data[i].name;

はただ以前に追加されたすべてのものに置き換えられます。

output.innerHTML += res.data[i].id + "\n" + res.data[i].name;

あなたの問題を解決します。

+0

その作品があなたを.Thank'連結された連結ではありません! – jonm

0

上書きするためoutput.innerHTMLのforループのようにlast valueのみが存在します。

使用BAD appendChild()

output.appendChild(res.data[i].id + "\n" + res.data[i].name); 
関連する問題