- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Laravel 5.1
我有一个客户表。客户将创建自己的帐户并等待管理员批准。管理员可以随时激活、停用或阻止它们。我在表格底部有三个链接(如果需要,我可以更改为按钮)ACTIVE
, DEACTIVATE
& BLOCK
.每行还有一个复选框。
现在,我想选择一个或多个客户端并更改 status
的值领域member
数据库中的表。
这是我的观点代码:
<table border="1">
<tr>
<td></td>
<td>Name</td>
<td>Activity</td>
<td>main Activity</td>
<td>Legal Status</td>
<td>SIREN Code</td>
<td>Contact Firstname</td>
<td>Contact Lastname</td>
<td>Contact Email</td>
<td>Contact Telephone</td>
<td>Address</td>
<td>Town</td>
<td>Area</td>
<td>Region</td>
<td>Creation Date</td>
<td>Offer Pack Name</td>
<td>Login Password</td>
<td>Status</td>
</tr>
@foreach($clients as $client)
<tr>
<td>{!! Form::checkbox('client[]',$client->id,null) !!}</td>
<td>{{ $client->name }}</td>
<td>{{ $client->activity }}</td>
<td>{{ $client->main_activity }}</td>
<td>{{ $client->status }}</td>
<td>{{ $client->siren_code }}</td>
<td>{{ $client->contact_firstname }}</td>
<td>{{ $client->contact_lastname }}</td>
<td>{{ $client->email }}</td>
<td>{{ $client->contact_telephone }}</td>
<td>{{ $client->address }}</td>
<td>{{ $client->town }}</td>
<td>{{ $client->area }}</td>
<td>{{ $client->region }}</td>
<td>{{ $client->creation_date }}</td>
<td>{{ $client->offer_pack_name }}</td>
<td>{{ $client->password }}</td>
<td>{{ $client->status }}</td>
</tr>
@endforeach
</table>
<div class="col-md-10 text-center">
<a href="{{ action('AdminController@blockClient') }}" class="btn btn-default">BLOCK</a>
<a href="{{ action('AdminController@activateClient') }}" class="btn btn-default">ACTIVATE</a>
<a href="{{ action('AdminController@deactivateClient') }}" class="btn btn-default">ACTIVATE</a>
</div>
get('blockClient','AdminController@blockClient');
get('activateClient','AdminController@activateClient');
get('activateClient','AdminController@deactivateClient');
最佳答案
这是分步解决方案,它反射(reflect)了您在评论中向我解释的内容。
前言
首先,您将拥有两个功能而不是三个,激活和停用,我认为停用与阻止用户相同。
现在我想解释一下这是如何工作的,通常当您在 Laravel 中提交表单时,您可以通过表单发布数据并在 Controller 中获取数据以进行进一步处理。在我们的例子中,我们想要更新单个或多个选择,因此我们需要将我们想要激活或停用的所有客户端 ID 传递给我们的 Controller 。
由于我们可能有多个客户端,因此我们需要像您一样将所有选定的客户端作为数组传递给 Controller ,这很好。
在我们的 Controller 中,我们遍历所有选定的客户端,并根据我们的按钮操作激活或停用它们。
正如您在下面的快照中看到的,当我们选择客户端 1 和 2 并单击激活时,我们将看到数据库中的表对于两个选定的客户端都更新为 1。
如何测试?
对于调试,您可以使用 dd($results);
之前 $this->activateClient($results);
单击激活查看提交了哪些数据。
激活和停用按钮发送相同的选定客户端,但执行来自 formAction
的不同操作方法。
解决方案
这导致以下解决方案:
1-首先,您应该更正路由以接受发布,因此我们可以将带有客户端 ID 的复选框传递给 Controller 函数:
get('admin','AdminController@index');
post('admin/action', array('uses' => 'AdminController@formAction'));
use App\client;
在您的
AdminController
中的命名空间之后:
public function index()
{
$client = Client::all();
return view('Admin', ['client' => $client]);
}
public function formAction()
{
$results = Input::get('status');
if (Input::get('activate'))
{
$this->activateClient($results);
} elseif (Input::get('Deactivate'))
{
$this->deactivateClient($results);
}
return redirect('admin');
}
public function activateClient($client)
{
foreach ($client as $clientId)
Client::findOrNew($clientId)->update(['status' => "1"]);
}
public function deactivateClient($client)
{
foreach ($client as $clientId)
Client::findOrNew($clientId)->update(['status' => "0"]);
}
ZERO (0)
:
<p>Admin site | client activate and deactivate page:</p>
{!! Form::open(array('url' => 'admin/action')) !!}
<table width="800px">
<tr>
<td width="10%">Select</td>
<td width="20%">Client id</td>
<td width="20%">Client status</td>
<td width="50%">Client name</td>
</tr>
@foreach ($client as $clientOutput)
<tr>
<td>{!! Form::checkbox('status[]', $clientOutput->id, false, ['id' => $clientOutput->id]) !!}</td>
<td>{{$clientOutput->id}}</td>
<td>{{$clientOutput->status}}</td>
<td>{{$clientOutput->client}}</td>
</tr>
@endforeach
</table>
{!! Form::submit('Activate', ['name' => 'activate']) !!}
{!! Form::submit('Deactivate', ['name' => 'Deactivate']) !!}
{!! Form::close() !!}
关于checkbox - 在 Laravel 中激活/停用多个客户端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33375406/
在检查复选框时我发现有写 CheckBox checkbox = (CheckBox)sender 在 checkBox1_CheckedChanged 事件上。 请解释一下这是什么意思? 最佳答案
我正在使用来自命名空间 System.Windows.Forms 的 ToolTip 类编辑我的 Web 应用程序;我的代码中有几个复选框,因此显示此错误: 'CheckBox' is an ambi
我正在制作 Bootstrap 复选框下拉菜单,选项包含在 中。处理点击的标签,但我也有一个 在 a 标签内。 当用户按下实际复选框而不是仅按下 时,就会出现我的问题。元素。两者都被点击并且发生了
TLDR:使用defaultChecked而不是checked,工作jsbin . 尝试设置一个简单的复选框,在选中时会划掉其标签文本。由于某种原因,当我使用该组件时,handleChange 没有被
我想拥有它,所以如果复选框为 NULL 或 0,则它不像值为 1 时那样喜欢。另外,有没有办法将选中的框限制为 10 个? 当前代码: if(isset($_POST['submit'])){//to
如果我选中一个复选框,下拉列表应该只显示在该复选框旁边,但它会显示在它下面的所有其他复选框中。 这是我在 html 代码中使用的 css .sub-nav { display: none; } inp
我在警报对话框中有一个带有复选框的数据表,当我单击该复选框时,它没有选中(选中=选中)该框。我跟着这个video 这是我的尝试 import 'package:flutter/material.dar
如果单独使用,以下代码效果很好, Angular6.0 不允许 [(ngModel)] 与 FormGroup (Reactive Forms)。 As 在 angular 6.0 中已弃用,并将在
那么我应该使用哪个来选择元素?我仅使用复选框作为示例,这个问题涉及所有表单元素。 实际上,当我们这样做时,哪个更快: li:first 或 li:eq(0) ? 最佳答案 来自the document
问题 : 我有一个列表框,其中列表框是复选框。在第一次单击时,复选框被选中并选中。在第二次单击时,仅设置复选框。可以使用箭头键重新选择不同的复选框。我的目标是,首先选中该复选框,然后再检查(再次单击它
我似乎无法弄清楚如何让复选框和相关文本出现在一行上。文本很短,所以它似乎不是宽度问题。 我尝试在控件上设置 display:inline,但是当它呈现时,在输入和标签周围添加了一个跨度,并且具有 di
创建带有复选框列的 Table 非常容易,例如,使用 SWT.CHECK 标志。但是如何使某些表格行中的复选框不可编辑而其他行中的复选框保持可编辑? 最佳答案 我不知道这样做的简单方法。 但我看到了两
是否可以使用 TogglerBar 而不是 2 个复选框来显示或不显示不同的形状。 TogglerBar 的每个按钮中都写有绿色和红色? Manipulate[ Graphics[{If[thePin
我需要更改 Windows Phone 8 中 LongListMultiSelector 的复选框的颜色,因为我的背景是白色,这可能吗? 谢谢。 最佳答案 为此,您必须首先通过在 visual st
我有一个带有插件 Slick.CheckboxSelectColumn 的网格。 是否可以在没有 Jquery 的情况下隐藏某些行中的复选框?我想可以使用 Formatter。 这是带有 slickg
所以我有这个... 在这里,id 是有道理的值在引号中,因为它是一个字符串标识符。但是type呢?值(value)?不是 checkbox一种类型,例如 String 和 Boolean?为什么我总
问题: 如果用户选中了复选框,我将尝试验证下拉列表,如您在屏幕一中所见。 问题: 那么,如果用户选择了标题中的所有复选框,我该如何验证复选框呢?如您所见,屏幕二。如果我选中所有复选框,那么我希望启动验
我知道它有点重复,我正在尝试以不同的方式做到这一点,从而重新发布这个问题。 我想要实现的是,当有人“取消选中”OSPF 复选框时..被动接口(interface)检查也应该自动“取消选中”。我正在尝试
这是代码(是的,我使用的是基本的 reset.css): .checkbox { border: 1px solid black; width: 10px; height: 10px; }
我正在尝试显示多组带有标题复选框的复选框,如下图所示。 从数据库中我得到这样的数据, CODE SUBCODE DESCR DESCR
我是一名优秀的程序员,十分优秀!