将复选框值传递给laravel控制器

时间:2018-07-07 06:28:50

标签: javascript jquery laravel forms

我需要使用jQuery获取复选框的值并将其传递给我的Laravel控制器,以便将值存储在数据库中。

我需要将值设置为true或false / 1或0 ...不能为null。

如何将复选框的值传递给数据库?

以下是复选框:

<input type="checkbox" value="true" name="cats" id="cat" checked>

这是我的脚本,它也可以毫无问题地获取其他值:

function updateExtraFields(fieldName, selector) {
    $('form input[name="' + fieldName + '"]').val($(selector).val());
}

$('#cat').on('click', function() {
    updateExtraFields('cats', '#cat').prop('checked');
 });

$('#dog').on('change', function() {
    updateExtraFields('dogs', '#dog');
});

$('#bird').on('change', function() {
    updateExtraFields('birds', '#bird');
});

//Something else I was trying... $("#cat").attr("checked") ? 1 : 0;

控制器:

$xxxx->table_name()->create([
    'cats' => $request->cats === 'true',
    'dogs' => $request->dogs,
    'birds' => $request->birds,
]);

更新/答案 我最终弄清楚了我的问题。我需要创建一个隐藏字段以将复选框值传递给它,然后才能将其存储在数据库中

<input type="checkbox" value="" name="cats" id="cat" checked>

<input type="hidden" value="" name="cats" id="hidden_check">

 $(document).ready(function() { 
//Added value on page load
$('#cat').attr('value', '1')
$('#hidden_check').attr('value', '1')

 // Changed value when checked
  $('#cat').on('change', function() {
      if ($(this).is(':checked')) {
    $(this).attr('value', '1');
  } else {
    $(this).attr('value', '0');
  }  

//Sent value to hidden field
    var checkbox_field_value = $(this).val();
    $('#hidden_check').val(checkbox_field_value);
  });
});

此代码对我有用,但是如果有更简洁的编写方法,请告诉我。

2 个答案:

答案 0 :(得分:0)

$xxxx->table_name()->create([
  'cats' => $request->cats == 'true' ? 'true' : 'false',
  'dogs' => $request->dogs,
  'birds' => $request->birds,
]);

如果$request->cats等于'true',则将true用作cats的值。如果还有其他值,则为false。希望这行得通。

答案 1 :(得分:0)

您可以使用Ajax将值传递给控制器​​。以下代码演示了如何实现

var catStatus=$('input[name="cats"]:checked');  // get the value of the checkbox

/*Now make the ajax call*/
$.ajax({
    headers: {
        'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
    },
    url: '/sendcatStatus',
    datatType : 'json',
    type: 'POST',
    data: {
        status: catStatus
    },
    success:function(response) {
        alert(response);
    }
});

/*Laravel route*/
Route::post('/sendcatStatus','ControllerName@methodName');

/*Your Contoller Method */

public function methodName(Request $request){

    dd($request->input('status'));
}

我已经为一个复选框显示了它。同样,您可以使用ajax调用来发送多个数据。