我在Laravel 7中遇到Ajax问题

如何解决我在Laravel 7中遇到Ajax问题

对于选择输入,我具有以下ajax代码

$("#franchise").change(function() {
    //alert( $( "#franchise" ).val() );
    var f = $( "#franchise" ).val();
    $.ajaxSetup({
      headers: {
        'X-CSRF-TOKEN': $('Meta[name="csrf-token"]').attr('content')
      }
    });
    $.ajax({
      type: 'POST',url  : "{{ route('ajax.series') }}",data : ({franchise : f}),dataType: 'JSON',success: function(response) {
        $("#series").html('');
        $("#series").append(response);
      }
    });
});

我也遵循以下路线:

Route::post('ajax/series','AjaxController@series')->name('ajax.series');

我在AjaxController中具有以下代码

public function series(Request $request)
{
    $id = $request->input('franchise');//I get the id data from select input
    $series = Serie::where('franchise_id',$id)->get();
    return view('ajax.series',['series' => $series]);
}

但是当我执行选择事件时,什么也没发生。

我知道change事件有效,因为我仅使用alert进行了检查,因此问题可能出在ajax。有什么问题吗?

解决方法

$("#franchise").change(function() {
    //alert( $( "#franchise" ).val() );
    var f = $( "#franchise" ).val();
    $.ajaxSetup({
      headers: {
        'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
      }
    });
    $.ajax({
      type: 'POST',url  : 'ajax/series',data : ({franchise : f}),dataType: 'JSON',success: function(response) {
        $("#series").html('');
        $("#series").append(response);
      }
    });
});
,

只需在文档就绪功能中移动下面的代码

$.ajaxSetup({
      headers: {
        'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
      }
});

在您的通用布局文件中添加{{ csrf_field() }}

确保您的js代码位于同一文件中,而不是外部js,然后使用以下js代码

$("#franchise").change(function() {
    //alert( $( "#franchise" ).val() );
    var f = $( "#franchise" ).val();
    $.ajax({
      type: 'POST',url  : "{{ route('ajax.series') }}",success: function(response) {
        $("#series").html('');
        $("#series").append(response);
      }
    });
});
,

@sandy是正确的,这肯定会解决您的问题,此外,您还可以在浏览器开发人员工具中检查ajax调用,以查看那些调用实际上在触及控制器的方法。

对于Chrome,其Ctrl + Shift + I

Click to view Image

调试愉快!

,

您的控制器和路由代码都很好,但是您的javaScript代码在这里有一个小问题,在laravel中,无需为CSRF令牌添加ajax标头字段,您可以像添加了CSRF令牌一样将CSRF令牌添加为ajax主体专营权和代码将完全正常。

我已经为您编写了代码,供您尝试。

    $('#franchise').change(function(e) {
        e.preventDefault();
        $.ajax({
            type: "POST",url: "{{ route('ajax.series') }}",data: {
                franchise: $(this).val(),_token: $('meta[name="csrf-token"]').attr('content'),},success: function(response) {
                $("#series").html('').append(response);
            }
        });
    });

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?