【问题标题】:Jquery and Ajax Error Message cannot Display in Laravel BladeJquery 和 Ajax 错误消息无法在 Laravel Blade 中显示
【发布时间】:2017-11-26 13:33:17
【问题描述】:

我在 Laravel 中使用 Ajax 和 Jquery 插入分类帐记录。成功消息已正确显示,但错误自定义消息无法在刀片视图中显示。请指出我的错误。

jQuery :

$("#add").click(function(event) {
  event.preventDefault();

  $.ajax({
    type: 'post',
    url: $("#add").attr('data-url'),
    data: {
      '_token': $("input[name=_token]").val(),
      'form_data': $('#Form').serialize(),
    },
    success: function(data) {
      $('#ledger_name').val('');
      $('#openning_balance').val('');
      $('#ob_type').val('');
      $('#under').val('');
      $('#ledger_address').val('');
      $("#newLedger .close").click();

      $(".result").html(data.success).css({
        'color': 'green',
        'text-align': 'center'
      }).delay(5000).fadeOut();
    },
    error: function(data) {
      $('#response').show().html(data.error).css({
        'color': 'red',
        'text-align': 'center'
      }).delay(5000).fadeOut();
    }
  });
});

控制器:

$values = array();
    parse_str($_POST['form_data'], $values);

    $validation = $this->validator($values,true );
    if($validation->fails()){
    $errors = $validation->errors();
    return response()->json(['error' => 'Please Fill all Mandatory Fields',],500);
    }

    $insertledgers=Ledger::create(['ledger_name'=>$values['ledger_name'],'openning_balance'=>$values['openning_balance'],'ob_type'=>$values['ob_type'],'under'=>$values['under'],'ledger_address'=>$values['ledger_address'],'company_id'=>$companyids,'user_id'=>$usersid,'created_by'=>$usersid]);

    $ledgerinsertids=$insertledgers->id;

    if($values['ob_type'] == 'Cr'){

    $creditamts=$values['openning_balance'];
    $debitamts= 0;

    } else {

    $creditamts=0;
    $debitamts= $values['openning_balance'];

    }

    $insertledgeropenningbalance=Openningbalance::create(['ledgerid'=>$ledgerinsertids,'opening_credit'=>$creditamts,'opening_debit'=>$debitamts,'company_id' => $companyids,'user_id' => $usersid,'created_by' => $usersid,]);

    return response()->json(['success' => 'Ledger Details Added Successfully',],200);   

【问题讨论】:

  • 发布您的刀片视图
  • 改进的代码格式

标签: php jquery laravel laravel-5.4


【解决方案1】:

你只需要修改你的错误回调函数如下:

error : function (data) {
    $('#response').show().html(data.responseJSON.error).css({
        'color': 'red',
        'text-align': 'center'
    }).delay(5000).fadeOut();
}

感谢@voodoo417

【讨论】:

  • 抱歉,但您的“解决方案”很糟糕……您是否看到响应返回 500 错误和 200 成功?当然它不会起作用。
  • @voodoo417:我没有注意到第二个参数。谢谢!
【解决方案2】:

试试这个:

<?php
use Validator;

class SomeController extends Controller {

  public function SomeFunction(Request $request) {
    $values = array();
    parse_str($_POST['form_data'], $values);

    $validation = Validator::make($values, true);

    if($validation->fails()){
      $errors = $validation->errors();
      return response()->json(['error' => 'Please Fill all Mandatory Fields'], 500);
    }

    $insertledgers=Ledger::create(['ledger_name'=>$values['ledger_name'],'openning_balance'=>$values['openning_balance'],'ob_type'=>$values['ob_type'],'under'=>$values['under'],'ledger_address'=>$values['ledger_address'],'company_id'=>$companyids,'user_id'=>$usersid,'created_by'=>$usersid]);

    $ledgerinsertids=$insertledgers->id;

    if($values['ob_type'] == 'Cr'){

      $creditamts=$values['openning_balance'];
      $debitamts= 0;

    } else {

      $creditamts=0;
      $debitamts= $values['openning_balance'];

    }

    $insertledgeropenningbalance=Openningbalance::create(['ledgerid'=>$ledgerinsertids,'opening_credit'=>$creditamts,'opening_debit'=>$debitamts,'company_id'
    => $companyids,'user_id' => $usersid,'created_by' => $usersid,]);

    return response()->json(['success' => 'Ledger Details Added Successfully',],200);

并且在视图中:

error: function(data)
{
$('#response').html(data.error).css({'color': 'red', 'text-align': 'center'})
$('#response').show().delay(5000).fadeOut();
}

【讨论】:

    猜你喜欢
    • 2021-12-29
    • 1970-01-01
    • 2016-02-15
    • 2021-07-27
    • 1970-01-01
    • 2016-09-25
    • 2018-12-07
    • 2021-03-02
    • 1970-01-01
    相关资源
    最近更新 更多