我需要使用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);
});
});
此代码对我有用,但是如果有更简洁的编写方法,请告诉我。
答案 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调用来发送多个数据。