Laravel Ajax下拉示例

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Laravel Ajax下拉示例相关的知识,希望对你有一定的参考价值。

有人可以分享laravel ajax dropdown的工作示例。有很多关于可靠下拉列表的例子,但是我想要只有一个列的简单下拉,我有两个表老师和国家,当教师档案打开时我想要使用ajax下拉国籍。我没有ajax就完成了,但我不知道如何处理ajax。没有ajax:

<select name="nation_id" class="custom-select" >
    <option selected value=" ">Choose...</option>
    @foreach($nations as $nations)
    <option value="{{@$nation_id}}"  {{@$teacher->nation_id== $nations->id ? 'selected' : ''}} >{{@$nations->nation}}</option>
@endforeach

控制器:

$nations = nation::all();
答案

为您的方法创建一条路线,以获取所有国家 -

Route::get('nations-list', 'YourController@method');

在控制器中为上述路径创建一个方法 -

public function method()
{
    $nations = Nation::all()->pluck('nation', 'id');

    return response()->json($nations)
}

html中添加这样的选择框 -

<select id="nation_id" name="nation_id"></select>

如果您想根据变量自动选择选项,那么您可以这样做 -

<input type="hidden" name="teacher_nation_id" id="teacher_nation_id" value="{{ $teacher->nation_id ?? '' }}">

然后在HTML中添加此脚本以在页面加载时获取国家/地区列表 -

<script>
$(document).ready(function($){
    $.get('nations-list', function(data) {
        let teacher_nation_id = $('#teacher_nation_id').val();
        let nations = $('#nation_id');
        nations.empty();

        $.each(data, function(key, value) {
            nations.append("<option value='"+ key +"'>" + value + "</option>");
        });

        nations.val(teacher_nation_id); // This will select the default value
    });
});
</script>
另一答案
<select class="form-control" name="nation_id" id="nation_id">
          <option value="">Select nation</option>
           @foreach($nations as $nation) 
            <option value="{{ $nation->nation_id }}">{{ $nation->nation_name }}  </option>
          @endforeach
</select>

<select class="form-control" name="teacher" id="teacher">
</select>

现在的ajax代码:

<script type="text/javascript">
$('#nation_id).change(function(){
    var nid = $(this).val();
    if(nid){
        $.ajax({
           type:"get",
           url:"{{url('/getTeacher)}}/"+nid,
           success:function(res)
           {       
                if(res)
                {
                    $("#teacher").empty();
                    $("#state").append('<option>Select Teacher</option>');
                    $.each(res,function(key,value){
                        $("#teacher").append('<option value="'+key+'">'+value+'</option>');
                    });
                }
           }

        });
        }
});
</script>

现在在控制器文件中;

public function getTeacher($id)
{
    $states = DB::table("teachers")
                ->where("nation_id",$id)
                ->pluck("teacher_name","teacher_id");
    return response()->json($teachers);    
}

最后一个路径文件:

Route::get('/getTeacher/{id}','TeachersController@getTeacher');

希望这会有效.. 祝好运...

以上是关于Laravel Ajax下拉示例的主要内容,如果未能解决你的问题,请参考以下文章

当用户使用 ajax 在 laravel 中选择任何下拉值时,如何立即显示数据库详细信息?

html PHP代码片段: - AJAX基本示例:此代码演示了使用PHP和JavaScript实现的基本AJAX功能。

php - Laravel:如何在从下拉列表中选择更改后加载 Ajax 数据?

在 laravel 中使用 ajax 用数据库填充下拉列表

Laravel ajax 帖子返回 500 内部服务器错误

onclick 使用 ajax laravel 从数据库中获取数据