表单回调

Form目前提供了下面几个方法来接收回调函数:

creating

在新增页面调用(非提交操作)

  1. $form->creating(function (Form $form) {
  2. if (...) { // 验证逻辑
  3. $form->responseValidationMessages('title', 'title格式错误');
  4. // 如有多个错误信息,第二个参数可以传数组
  5. $form->responseValidationMessages('content', ['content格式错误', 'content不能为空']);
  6. }
  7. });

editing

在编辑页面调用(非提交操作)

  1. $form->editing(function (Form $form) {
  2. if (...) { // 验证逻辑
  3. $form->responseValidationMessages('title', 'title格式错误');
  4. // 如有多个错误信息,第二个参数可以传数组
  5. $form->responseValidationMessages('content', ['content格式错误', 'content不能为空']);
  6. }
  7. });

submitted

在表单提交前调用,在此事件中可以修改、删除用户提交的数据或者中断提交操作

  1. $form->submitted(function (Form $form) {
  2. // 获取用户提交参数
  3. $title = $form->title;
  4. // 上面写法等同于
  5. $title = $form->input('title');
  6. // 删除用户提交的数据
  7. $form->deleteInput('title');
  8. // 中断后续逻辑
  9. return $form->error('服务器出错了~');
  10. });

saving

保存前回调,在此事件中可以修改、删除用户提交的数据或者中断提交操作

  1. $form->saving(function (Form $form) {
  2. // 判断是否是新增操作
  3. if ($form->isCreating()) {
  4. }
  5. // 删除用户提交的数据
  6. $form->deleteInput('title');
  7. // 中断后续逻辑
  8. return $form->error('服务器出错了~');
  9. });

saved

保存后回调,此事件新增和修改操作共用,通过第二个参数$result可以判断数据是否保存成功。

{tip} 新增页面下,$result的值是新增记录的自增ID

  1. $form->saved(function (Form $form, $result) {
  2. // 判断是否是新增操作
  3. if ($form->isCreating()) {
  4. // 自增ID
  5. $newId = $result;
  6. // 也可以这样获取自增ID
  7. $newId = $form->getKey();
  8. if (! $newId) {
  9. return $form->error('数据保存失败');
  10. }
  11. return;
  12. }
  13. // 修改操作
  14. });

{tip} $form->repository()->eloquent()為當前新增或編輯後的eloquent

  1. $form->saved(function (Form $form, $result) {
  2. // 在表單保存後獲取eloquent
  3. $form->repository()->eloquent()->update(['data' => 'new']);
  4. });

deleting

删除前回调

  1. $form->deleting(function (Form $form) {
  2. // 获取待删除行数据,这里获取的是一个二维数组
  3. $data = $form->model()->toArray();
  4. });

deleted

删除后回调,通过第二个参数$result可以判断数据是否删除成功。

  1. $form->deleted(function (Form $form, $result) {
  2. // 获取待删除行数据,这里获取的是一个二维数组
  3. $data = $form->model()->toArray();
  4. // 通过 $result 可以判断数据是否删除成功
  5. if (! $result) {
  6. return $form->error('数据删除失败');
  7. }
  8. // 返回删除成功提醒,此处跳转参数无效
  9. return $form->success('删除成功');
  10. });

uploading

图片、文件上传事件

{tip} 文件上传是一个独立的api请求,这个事件内redirect方法是无效的。

  1. use Dcat\Admin\Form;
  2. use Dcat\Admin\Form\Field;
  3. use Dcat\Admin\Contracts\UploadField as UploadFieldInterface;
  4. use Symfony\Component\HttpFoundation\File\UploadedFile;
  5. $form->uploading(function (Form $form, UploadFieldInterface $field, UploadedFile $file) {
  6. // $file 即是当前上传的完整文件
  7. /* @var Field $field */
  8. // 获取文件上传字段名称
  9. $column = $field->column();
  10. });

uploaded

图片、文件上传完毕事件

{tip} 文件上传是一个独立的api请求,这个事件内redirect方法是无效的。

  1. use Dcat\Admin\Form;
  2. use Dcat\Admin\Form\Field;
  3. use Dcat\Admin\Contracts\UploadField as UploadFieldInterface;
  4. use Symfony\Component\HttpFoundation\File\UploadedFile;
  5. $form->uploaded(function (Form $form, UploadFieldInterface $field, UploadedFile $file, $response) {
  6. // $file 即是当前上传的完整文件
  7. /* @var Field $field */
  8. // 获取文件上传字段名称
  9. $column = $field->column();
  10. $response = (array) $response->getData();
  11. // 文件上传成功
  12. if ($response['status']) {
  13. // 文件访问地址
  14. $url = $response['url'];
  15. }
  16. });

获取模型中的数据

  1. $form->saved(function (Form $form) {
  2. $id = $form->getKey();
  3. $username = $form->model()->username;
  4. // 获取最终保存的数组
  5. $updates = $form->updates();
  6. });

修改或删除用户提交的数据

此功能在savingsubmitted事件中有效

  1. $form->select('author_id');
  2. $form->saving(function (Form $form) {
  3. // 修改用户提交的数据
  4. $form->author_id = 1;
  5. // 删除、忽略用户提交的数据
  6. $form->deleteInput('author_id');
  7. });

修改模型中的数据

修改模型中的数据需要配合隐藏表单使用。举例:

  1. $form->hidden('author_id');
  2. $form->saving(function (Form $form) {
  3. $form->author_id = 1;
  4. });

页面跳转

{tip} 此方法在creatingeditinguploadinguploaded事件中均不可用。

redirect(局部刷新/单页刷新)

  1. // 跳转并提示成功信息
  2. $form->saved(function (Form $form) {
  3. return $form->redirect('auth/user', '保存成功');
  4. });
  5. // 跳转并提示错误信息
  6. $form->saved(function (Form $form) {
  7. return $form->redirect('auth/user', [
  8. 'message' => '系统错误',
  9. 'status' => false,
  10. ]);
  11. });

{tip} Since v1.6.0

location(刷新整个页面)

  1. // 跳转并提示成功信息
  2. $form->saved(function (Form $form) {
  3. // 不传参数则刷新当前页面
  4. // return $form->location();
  5. return $form->location('auth/user', '保存成功');
  6. });
  7. // 跳转并提示错误信息
  8. $form->saved(function (Form $form) {
  9. return $form->location('auth/user', [
  10. 'message' => '系统错误',
  11. 'status' => false,
  12. ]);
  13. });

仅返回错误信息但不跳转

通过error方法可以在提交表单时返回错误提示信息

{tip} 此方法在creatingeditinguploadinguploaded事件中均不可用。

  1. $form->saving(function (Form $form) {
  2. return $form->error('系统异常');
  3. });

返回字段验证出错信息

通过responseValidationMessages方法可以很方便的返回字段验证出错信息,而不需要使用Laravel validation功能。

普通使用

  1. protected function form()
  2. {
  3. return Form::make(new Model(), function (Form $form) {
  4. if (...) { // 验证逻辑
  5. $form->responseValidationMessages('title', 'title格式错误');
  6. // 如有多个错误信息,第二个参数可以传数组
  7. $form->responseValidationMessages('content', ['content格式错误', 'content不能为空']);
  8. }
  9. });
  10. }

在事件中使用

{tip} 此方法仅在submitted事件中可用

  1. $form->submitted(function (Form $form) {
  2. // 接收表单参数
  3. $title = $form->title;
  4. if (...) { // 验证逻辑
  5. $form->responseValidationMessages('title', 'title格式错误');
  6. // 如有多个错误信息,第二个参数可以传数组
  7. $form->responseValidationMessages('content', ['content格式错误', 'content不能为空']);
  8. }
  9. });