我想将获取的数据库值传递给模态弹出窗口。我已从数据库中获取值并列为带分页的表。
'名称'字段有链接,并在触发链接时显示模型弹出窗口。我想列出我从laravel 5.3中的链接检查的名称的详细信息。
现在模型弹出与模态标题3'对于所有link.I想知道如何传递值模态弹出窗口并显示特定id的详细信息。我想知道我需要单独的页面或控制器来执行此操作。在哪里编写模式弹出的查询。如何显示特定Id的详细信息。
id name age
1 xx 26
2 yy 28
3 zz 30
<table border = 1>
<tr>
<td>ID</td>
<td>Passanger Name</td>
<td>Destination</td>
<td>Created Date</td>
</tr>
@foreach ($users as $user)
<tr>
<td>{{ $user->p_id }}</td>
<td><a href="#" class="viewPopLink" role="button" data-id="{{ $user->p_id }}" data-toggle="modal" data-target="#myModal">{{ $user->p_name }}<a></td>
<td>{{ $user->destination }}</td>
<td>{{ $user->created_date }}</td>
</tr>
@endforeach
</table>
{{$users->links()}}
<div class="modal fade" id="myModal" role="dialog">
<div class="modal-dialog">
<!-- Modal content-->
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<h4 class="modal-title">Modal Header {{ $user->p_id }}</h4>
</div>
<div class="modal-body">
<p>Some text in the modal.</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
</div>
</div>
</div>
答案 0 :(得分:4)
你可以像@Komal建议的那样去做,但我不会再做另一个AJAX请求,因为你已经拥有当前视图中模态所需的所有数据。这样您也可以免于编写另一个控制器。
将您需要的数据添加到<a>
元素中,并使用它将数据填入模态弹出窗口,方法是为模态添加一个简单的“on load”方法。
这是代码。
<td>
<a href="#" class="viewPopLink" role="button"
data-id="{{ $user->p_id }}" data-name="{{ $user->p_name }}" data-age="{{ $user->p_age }}"
data-toggle="modal" data-target="#myModal">{{ $user->p_name }}<a>
</td>
将其添加到模态体中:
<p>
<span>ID</span><span id="modal_p_id"></span>
<span>Name</span><span id="modal_p_name></span>
<span>Age</span><span id="modal_p_age"></span>
</p>
将此脚本添加到您的视图中:
<script>
/* populate the modal popup when it's launched, with the data provided by the launching button .... */
$('#myModal').on('show.bs.modal', function (event) {
var button = $(event.relatedTarget); // Button that triggered the modal
var id = button.data('id'); // Extract info from data-* attributes
var age = button.data('age');
var name = button.data('name');
// Update the modal's content
var modal = $(this);
modal.find('.modal-title').text('Information for Passenger ' + name);
modal.find('#modal_p_id').text(id);
modal.find('#modal_p_name').text(filename);
modal.find('#modal_p_age').text(age);
});
</script>
答案 1 :(得分:1)
使用jquery ajax请求并获取用户数据来设置模态
$(document).on('click', '.viewPopLink', function() {
var user_id = $(this).data('id');
$.ajax({
url: 'user/get-details',
type: 'GET',
data: 'id='+user_id,
dataType: 'JSON',
success: function(data, textStatus, jqXHR){
var name = data.name;
$('.modal-title').html('<span>Modal Header ' + name + '</span>');
$('#myModal').modal('show');
},
error: function(jqXHR, textStatus, errorThrown){
},
});
});
控制器方法
//Get user data
public function getDetails(Request $request)
{
$request_data = $request->all();
$user_id = $request_data['id'];
$user_data = User::where('id', $user_id)->first();
return response()->json($user_data);
}