为了账号安全,请及时绑定邮箱和手机立即绑定

Laravel:使用 ajax 搜索,路由无法正常工作

Laravel:使用 ajax 搜索,路由无法正常工作

我有 Laravel 网络应用程序包含对数据库的搜索。首先我有这个输入:<input class="form-control mr-sm-2" type="text"  id="search_me" placeholder="{{__('home.Search')}}" aria-label="Search" onkeyup="myFunction()"><input type="hidden" id="course_id" value="{{$course->id}}">所以我创建了这个 JavaScript 函数:    <script>        function myFunction() {            var search_me=document.getElementById('search_me').value;            var id=document.getElementById('course_id').value;                    $.ajax({                        method : 'POST',                        url : "{{route ('search')}}",                        dataType : 'json',                        data:{                            '_token':'{{csrf_token()}}',                            'search_data':search_me ,                             'course_id':id,                            },                                                success:function(data){                        console.log(data);                         }                    });          }</script>然后我像这样创建路线:Route::get('/search', [App\Http\Controllers\user\User_controller::class, 'search_data'])->name('search');和控制器方法:public function search_data(Request $request){        $output="";        $questions = Question::table('questions')->where('course_id',$request->course_id)->where('question' ,'LIKE' ,'%'.$request->search_data."%")->get();        return json_nencode($questions);}当我在文本输入上键入时出现错误:main.js?attr=DEbA4C86cFywU9oORVUcm4fay4bVMB7MeKBvEkL0Iy2jpADxMlMEszxyl6A-4lWVGp58XG2e-YEmLqgl2mGpQg:1078 POST http://127.0.0.1:8000/ku/search 405 (Method Not Allowed)在这个错误中我发现了这个:        return fun.apply(this, [].slice.call(arguments));我遵循了很多这样的例子,我不知道我的错误在哪里?
查看完整描述

3 回答

?
慕勒3428872

TA贡献1848条经验 获得超6个赞

在使用 $.ajax 请求之前尝试添加此代码


  $.ajaxSetup({

    headers: {

     'X-CSRF-TOKEN': "{{ csrf_token() }}"

   }

});

让我知道它是否有帮助,它也记录在官方 laravel 文档中。

在此之后,您不需要在 $.ajax 请求中添加 __token 。


查看完整回答
反对 回复 2023-05-11
?
三国纷争

TA贡献1804条经验 获得超7个赞

谢天谢地,我通过这种方式解决了它:路线:


Route::get('/search'.'/{search}/{course}', [App\Http\Controllers\user\User_controller::class, 'search_data'])->name('search');

js函数:


function myFunction(id) {

            var search_me=document.getElementById('search_me').value;

            var route = "{{URL::to('search')}}"+'/'+search_me+'/'+id;

            if(search_me != ""){

                $.get(route, function(data,status){

                    console.log(data);

                });

            }

        }

    </script>


查看完整回答
反对 回复 2023-05-11
?
德玛西亚99

TA贡献1770条经验 获得超3个赞

你的 ajax 方法是post,但你的路线是get


改变路线到post


Route::post('/search', [App\Http\Controllers\user\User_controller::class, 'search_data'])->name('search');

或者你的ajaxget


                  $.ajax({

                        method : 'GET',

                        url : "{{route ('search')}}",

                        dataType : 'json',

                        data:{

                            'search_data':search_me , 

                            'course_id':id,

                            },

                        

                        success:function(data){

                        console.log(data); 

                        }

                    });  


查看完整回答
反对 回复 2023-05-11
  • 3 回答
  • 0 关注
  • 132 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信