POST или GET значения PHP внутри цикла while с использованием модальных - PullRequest
0 голосов
/ 25 мая 2018

Ниже приведен mysqli-запрос пользователей, которые отображаются в таблице циклов while с именами в одном столбце и кликабельной ссылкой в ​​другом столбце.Я хотел бы щелкнуть OPEN, который использует javascript или даже что-то еще, например jquery, чтобы открыть экран модального наложения, и нажать кнопку сообщения, которая отправит POST или отправит значение PHP на ту же страницу или другую.Проблема ниже в том, что только первый $ id_friend отображается в модальном режиме в зависимости от того, включен он или нет.Пожалуйста, помогите найти лучший способ получить эти значения безопасно и легко.

<?php while($row = mysqli_fetch_array($result)) {  ?>

 $id_friend = $row['id_friend'];

 $firstName = $row['firstName'];


<table>
<tr>
<td><a><?php echo $firstName;  ?></a></td>
<td>

<!-- opens modal -->

<a href="#" id="<?php echo $row['friend_id'];?>" onclick="show(this.id)" >open </a>

<!-- modal -->

<div id="myNav2" class="overlay2">

<a href="javascript:void(0)" class="closebtn2" 
onclick="closeNav233()">&times;</a>

  <div class="overlay2-content">
     <div>
<form  action="getuser2.php" method="POST">
<button  name="friend_id" value="<?php echo $id_friend; ?>" 
type="submit">MESSAGE</button>
<input  class="friend_id" type="hidden" name="friend_id" value="<?php echo 
$id_friend; ?>" >
</form>
     </div>
  </div>
</div>

</td>
</tr>

<?php
 } //end of while loop
?> 

</table>

<script>
function show() {

document.getElementById("myNav2").style.width = "100%"; //opens modal

option = $(this).attr('id');
console.log(option ); //to check clicked id is Ok

$.ajax({
    url: 'testmodal.php',
    type: 'GET',
    data: {option : id},
    success: function(data) {
    alert($(this).data('id'));
    document.getElementById('myNav2').innerHTML =data;
    }
});

}

</script>

<style>
body {
font-family: 'Lato', sans-serif;
}

.overlay2 {
height: 100%;
width: 0;
position: fixed;
z-index: 1;
top: 0;
left: 0;
background-color: rgb(0,0,0);
background-color: rgba(0,0,0, 0.9);
overflow-x: hidden;
transition: 0.5s;
}

.overlay2-content {
position: relative;
top: 25%;
width: 100%;
text-align: center;
margin-top: 30px;
}

.overlay2 a {
padding: 8px;
text-decoration: none;
font-size: 36px;
color: #818181;
display: block;
transition: 0.3s;
}

.overlay2 a:hover, .overlay2 a:focus {
color: #f1f1f1;
}

.overlay2 .closebtn2 {
position: absolute;
top: 20px;
right: 45px;
font-size: 60px;
}

@media screen and (max-height: 450px) {
  .overlay2 a {font-size: 20px}
  .overlay2 .closebtn2 {
  font-size: 40px;
   top: 15px;
  right: 35px;
 }
 }
</style>

<script>

function closeNav233() {
document.getElementById("myNav2").style.width = "0%";
}
</script>

1 Ответ

0 голосов
/ 01 июня 2018
while($row = mysqli_fetch_array($result))  
{
$row['post_id'].$row['post_title'].$row['content']; 

}

это то, как столбцы в строке могут быть извлечены, вы используете некоторые ранее инициализированные данные при использовании first_name и friend_id

...