javascript — передать значение в модальное всплывающее окно, используя jquery, используя атрибут data-id в теге привязки

<div class="login-group">
<div class="form-group">
<table cellspacing="0" cellpadding="0" border="0" class="container">
<?php
$selectquery = "Select * from tblservices where category_id = 1";
$qry=mysqli_query($con,$selectquery);
if($qry)
{
$rowcount=mysqli_num_rows($qry);
if($rowcount>0)
{
$countI = 1;
while($obj=mysqli_fetch_array($qry))
{
if($countI==0)
{
?>
<tr>
<td class="bgimg">
<a href="#" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<?php echo $obj["service_name"]; ?>
</a>
</td>
<td>
<a href="#" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<img src="<?php echo '../assets/img/'.$obj['service_image']; ?>" alt="" >
</a>
</td>
</tr>
<?php
$countI = $countI + 1;
}
else if($countI %2 ==0)
{
?>
<!--<a href="#" data-id="<?php echo $obj["value1"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">show value</a>-->
<tr>
<td>
<a href="#" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<img src="<?php echo '../assets/img/'.$obj['service_image']; ?>" alt="" >
</a>
</td>
<td style="font-size:20px; text-align: center;" class="bgimg">
<a href="#" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<?php echo $obj["service_name"]; ?>
</a>
</td>
</tr>
<?php
$countI = $countI + 1;
}
else
{
?>
<tr>
<td style="font-size:20px; text-align: center;" class="bgimg">
<a href="#" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<?php echo $obj["service_name"]; ?>
</a>
</td>
<td>
<a href="#" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<img src="<?php echo '../assets/img/'.$obj['service_image']; ?>" alt="" >
</a>
</td>
</tr>
<?php
$countI = $countI + 1;
}
}
}
}
?>
</table>
</div>

Приведенный выше код отображает значения из базы данных с идентификатором данных в качестве идентификатора службы в теге привязки.

и этот идентификатор данных должен отображаться в модальном всплывающем окне, найти ниже

<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true" style="padding-top: 150px;">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">&times;</button>
<h4 class="modal-title" id="myModalLabel">Choose your slot</h4>
</div>
<div class="modal-body">
<input type="text" name="service_id" class="hiddenid"/>
<div class="form-group">
<table align="center">
<tr>
<td colspan="2"> <p class="white_text">Preferred slot 1</p></td>
</tr>
<tr>
<td style="padding-right: 10px;"><input type="date" id="theDate" name="slot1_dt" required> </td>
<td><input type="time" id="timePicker1" name="slot1_tm" required> </td>
</tr>
<tr>
<td colspan="2" style="padding-top: 15px;"><p class="white_text">Preferred slot 2</p></td>
</tr>
<tr>
<td style="padding-right: 10px;"><input type="date" id="theTomorrow" name="slot2_dt" required> </td>
<td><input type="time" id="timePicker2" name="slot2_tm" required> </td>
</tr>
<tr>
<td colspan="2" style="padding-top: 15px;">
<center><button type="submit" name="book" class="btn btn-default" value="book" style="font-size: 14px !important;">Book</button>
&nbsp;
<button type="button" class="btn btn-default" style="font-size: 14px !important;" data-dismiss="modal">Close</button></center>
</td>
</tr>
</table>

<?php
if(isset($_REQUEST["book"]))
{
if($_REQUEST["book"])
{
$service_id=$_REQUEST["service_id"];
$customer_id=$_REQUEST["cust_id"];
$slot1_dt=$_REQUEST["slot1_dt"];
$slot2_dt=$_REQUEST["slot2_dt"];
$slot1_tm=$_REQUEST["slot1_tm"];
$slot2_tm=$_REQUEST["slot2_tm"];
$slot1=$slot1_dt." ".$slot1_tm;
$slot1 = date("Y-m-d H:i:s",strtotime($slot1));
$slot2=$slot2_dt." ".$slot2_tm;
$slot2 = date("Y-m-d H:i:s",strtotime($slot2));
$insertqry="INSERT INTO `tblappointments`(`customer_id`, `service_id`, `preferred_slot1_date`, `preferred_slot2_date`)
VALUES ('$customer_id','$service_id','$slot1','$slot2')";
$res=mysqli_query($con, $insertqry) or die(mysqli_error($con));

if($res)
{
echo("successful.....");
}
}
}
?>
</div>
</div>
<div class="modal-footer"></div>
</div>
</div>
</div>

и JQuery используется для передачи значения

<?
$(".modalLink").click(function () {
var passedID = $(this).data('id');
$('#id').val(passedID);

//modifies input in modal
$(".modal-body .hiddenid").val(passedID);});
?>

эти коды находятся в одном файле php, а js хранится как отдельный файл

и на выходе я не могу получить значение идентификатора для передачи

текстовое поле все еще остается нулевым.

Кто-нибудь, пожалуйста, помогите мне.

1

Решение

Во-первых, удалить href="#" с href="#myModal".

<a href="#" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<img src="<?php echo '../assets/img/'.$obj['service_image']; ?>" alt="" >
</a>

Во-вторых, это не способ позвонить data-id.
Удалить var passedID = $(this).data('id'); с var dataId=$(this).attr('data-id'); Как ниже.

<?
$(".modalLink").click(function () {
var passedID=$(this).attr('data-id');
.
.
?>

Если это работает, хорошо. Если нет, следуйте моему коду шаг за шагом, это будет работать.

Итак, я предлагаю вам сделать одну страницу только для модальных (somepage.php). Где вы проходитеdataIdв надлежащем порядке, используя ajax,

1) Пиши свой <a></a> пометить как ниже. href="#myModal" является обязательным.

<a class="modalLink" href="#myModal" data-toggle="modal" data-id="<?php echo $obj["service_id"]; ?>">
<?php echo $obj["service_name"]; ?>
</a>

2) Поместите этот код в нижний колонтитул. (лайк footer.php)

<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true" style="padding-top: 150px;">
<div class="modal-dialog">
<div class="modal-content">

</div>
</div>
</div>

3) Назовите ваш ‘somepage.php’ (отдельная страница. Где присутствует модальное тело) через ajax. Поместите это <script></script> в вашем JS файл.

<script>
$('.modalLink').click(function(){
var dataId=$(this).attr('data-id');
$.ajax({url:"somepage.php?dataId="+dataId,cache:false,success:function(result){
$(".modal-content").html(result);
}});
});
</script>

4) Создайте somepage.php (Если вы хотите изменить имя этой страницы. Измените в <script></script> тоже. Оба связаны.)

somepage.php

<?

// Access $dataId like this way and use any where you want in this modal.

$dataId=$_GET['dataId'];
?>


<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">&times;</button>
<h4 class="modal-title" id="myModalLabel">Choose your slot</h4>
</div>
<div class="modal-body">
<input type="text" name="service_id" class="hiddenid" value="<?echo $dataId;?>"/>
<div class="form-group">
<table align="center">
<tr>
<td colspan="2"> <p class="white_text">Preferred slot 1</p></td>
</tr>
<tr>
<td style="padding-right: 10px;"><input type="date" id="theDate" name="slot1_dt" required> </td>
<td><input type="time" id="timePicker1" name="slot1_tm" required> </td>
</tr>
<tr>
<td colspan="2" style="padding-top: 15px;"><p class="white_text">Preferred slot 2</p></td>
</tr>
<tr>
<td style="padding-right: 10px;"><input type="date" id="theTomorrow" name="slot2_dt" required> </td>
<td><input type="time" id="timePicker2" name="slot2_tm" required> </td>
</tr>
<tr>
<td colspan="2" style="padding-top: 15px;">
<center><button type="submit" name="book" class="btn btn-default" value="book" style="font-size: 14px !important;">Book</button>
&nbsp;
<button type="button" class="btn btn-default" style="font-size: 14px !important;" data-dismiss="modal">Close</button></center>
</td>
</tr>
</table>

<?php
if(isset($_REQUEST["book"]))
{
if($_REQUEST["book"])
{
$service_id=$_REQUEST["service_id"];
$customer_id=$_REQUEST["cust_id"];
$slot1_dt=$_REQUEST["slot1_dt"];
$slot2_dt=$_REQUEST["slot2_dt"];
$slot1_tm=$_REQUEST["slot1_tm"];
$slot2_tm=$_REQUEST["slot2_tm"];
$slot1=$slot1_dt." ".$slot1_tm;
$slot1 = date("Y-m-d H:i:s",strtotime($slot1));
$slot2=$slot2_dt." ".$slot2_tm;
$slot2 = date("Y-m-d H:i:s",strtotime($slot2));
$insertqry="INSERT INTO `tblappointments`(`customer_id`, `service_id`, `preferred_slot1_date`, `preferred_slot2_date`)
VALUES ('$customer_id','$service_id','$slot1','$slot2')";
$res=mysqli_query($con, $insertqry) or die(mysqli_error($con));

if($res)
{
echo("successful.....");
}
}
}
?>
</div>
</div>
<div class="modal-footer">

</div>

Наслаждайтесь кодированием.

ОБНОВЛЕННЫЙ КОД (На @ Шридхар-х Требовать)

1) Изменить href="#" в href="#myModal" везде это присутствует в вашем коде для модального всплывающего окна.

<td class="bgimg">
<a href="#myModal" data-id="<?php echo $obj["service_id"]; ?>" data-toggle="modal" data-target="#myModal" class="modalLink">
<?php echo $obj["service_name"]; ?>
</a>
</td>

2) Используйте этот код в JS.

JS

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.2/jquery.min.js"></script>
<script>
$('.modalLink').click(function(){
var ID=$(this).attr('data-id');
$.ajax({url:"NewPage.php?ID="+ID,cache:false,success:function(result){
$(".modal-content").html(result);
}});
});
</script>

3) Поместите этот код в нижний колонтитул.

<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true" style="padding-top: 150px;">
<div class="modal-dialog">
<div class="modal-content">

</div>
</div>
</div>

4) Создать NewPage.php (Если вы хотите изменить имя страницы этой страницы. Пожалуйста, измените в Point-2 <script></script> тег тоже. Оба связаны)

NewPage.php

Доступ ID через _GET и делай что хочешь с этим ID

<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">&times;</button>
<h4 class="modal-title" id="myModalLabel">Choose your slot</h4>
</div>
<div class="modal-body">
<?php echo $_GET['ID'];?>
</div>
<div class="modal-footer"></div>
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]