# 后端(tp6)
表单令牌,感觉不好用。鸡肋,特别是ajax提交表单的时候,由于页面本身就不会更新,导致token更新不及时,无法提交。
# 前端限制(推荐)
## 标志控制
假如你是通过回车提交表单,那么只能用这种
## 按钮不可点击
是通过按钮提交的话,可以用这个方法
## 遮罩层
这个同样是不能处理回车提交表单,需要再使用 标志控制结合使用。我个人是喜欢用这种方式,这种方式,用户体验好一点,会给用户展示网络请求的状态
### 分别给每次请求单独设置(推荐)
因为不是所有的网络请求都是需要这个遮罩层的,一般只用于表单提交请求。这样控制比较灵活
### 下面是全局给jquery给一个提示
只要是用jquery发送ajax请求就会给出遮罩层
~~~bash
$.ajaxSetup({
timeout: 30000, //超时时间:30秒
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
},
beforeSend: function (xhr) {
if ($('.mask').length == 0) {
let fdsf = `
<div class="mask">
<div style="color: #f4696b" class="la-line-spin-fade-rotating la-2x">
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
</div>
</div>
`;
$(fdsf).prependTo('body');
}
},
//请求完毕事件
complete: function (xhr, status) {
//不管请求成功还是失败,都把这个遮罩层给删除
$('.mask').remove();
//超时timeout,还有success,error等值的情况
if (status === 'timeout') {
xhr.abort()// 超时后中断请求
Toast.fire({
icon: 'error',
title: "请求超时~"
});
} else {
let text = xhr.responseText;
if (isJSON(text)) {
let res = JSON.parse(text);
if (res.code === 419) {
Toast.fire({
icon: 'error',
title: res.msg
});
}
}
}
}
});
~~~
## 标志控制和按钮不可点击代码延时
根据业务情况,可以自己改改
~~~javascript
//验证码发送标志
let send_flag = false;
//发送验证码触发点击事件
$('.send-btn').on('click', function () {
//当前按钮jq对象
let $send_btn = $(this);
if (send_flag) return;
send_flag = true;
//让按钮不可点击
$send_btn.attr('disabled', true);
//获取表单序列化数据
let data = $('.form').serialize();
//发送ajax发送邮箱验证码
$.ajax({
url: "<{url('/validate/email/send')}>",
type: 'POST',
data,
dataType: 'json',
success: function (res) {
//标志恢复
send_flag = false;
//让按钮可以点击
$send_btn.attr('disabled', false);
}
})
});
~~~
# 总结
同时推荐,所有的表单提交都通过ajax来完成,原因是,如果是传统的表单提交,那么后端验证不通过,就会再次返回添加页面(页面进行了跳转),如果不处理已填数据的回显,那么如果表单特别多的情况下,用户会非常反感。
所以,我们推荐用ajax的提交方式,验证不通过,直接js提示
- thinkphp6执行流程(一)
- php中use关键字用法详解
- Thinkphp6使用腾讯云发送短信步骤
- 路由配置
- Thinkphp6,static静态资源访问路径问题
- ThinkPHP6.0+ 使用Redis 原始用法
- smarty在thinkphp6.0中的最佳实践
- Thinkphp6.0 搜索器使用方法
- 从已有安装包(vendor)恢复 composer.json
- tp6with的用法,表间关联查询
- thinkphp6.x多对多如何添加中间表限制条件
- thinkphp6 安装JWT
- 缓存类型
- 请求信息和HTTP头信息
- 模型事件用法
- 助手函数汇总
- tp6集成Alipay 手机和电脑端支付的方法
- thinkphp6使用jwt
- 6.0session cookie cache
- tp6笔记
- TP6(thinkphp6)队列与延时队列
- thinkphp6 command(自定义指令)
- command(自定义指令)
- 本地文件上传
- 缓存
- 响应
- 公共函数配置
- 七牛云+文件上传
- thinkphp6:访问多个redis数据源(thinkphp6.0.5 / php 7.4.9)
- 富文本编辑器wangEditor3
- IP黑名单
- 增删改查 +文件上传
- workerman 定时器操作控制器的方法
- 上传文件到阿里云oss
- 短信或者邮箱验证码防刷代码
- thinkphp6:访问redis6(thinkphp 6.0.9/php 8.0.14)
- 实现关联多个id以逗号分开查询数据
- thinkphp6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 用mpdf生成pdf文件(php 8.1.1 / thinkphp v6.0.10LTS )
- 生成带logo的二维码(php 8.1.1 / thinkphp v6.0.10LTS )
- mysql数据库使用事务(php 8.1.1 / thinkphp v6.0.10LTS)
- 一,创建过滤IP的中间件
- 源码解析请求流程
- 验证码生成
- 权限管理
- 自定义异常类
- 事件监听event-listene
- 安装与使用think-addons
- 事件与多应用
- Workerman 基本使用
- 查询用户列表按拼音字母排序
- 扩展包合集
- 查询用户数据,但是可以通过输入用户昵称来搜索用户同时还要统计用户的文章和粉丝数
- 根据图片的minetype类型获取文件真实拓展名思路
- 到处excel
- 用imagemagick库生成缩略图
- 生成zip压缩包并下载
- API 多版本控制
- 用redis+lua做限流(php 8.1.1 / thinkphp v6.0.10LTS )
- 【thinkphp6源码分析三】 APP类之父, 容器Container类
- thinkphp6表单重复提交解决办法
- 小程序授权
- 最简单的thinkphp6导出Excel
- 根据访问设备不同访问不同模块
- 服务系统
- 前置/后置中间件
- 给接口api做签名验证(php 8.1.1 / thinkphp v6.0.10LTS )
- 6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 使用前后端分离的验证码(thinkphp 6.0.9/php 8.0.14/vue 3.2.26)
- 前后端分离:用jwt+middleware做用户登录验证(php 8.1.1 / thinkphp v6.0.10LTS )
- vue前后端分离多图上传
- thinkphp 分组、页面跳转与ajax
- thinkphp6 常用方法文档
- 手册里没有的一些用法
- Swagger 3 API 注释
- PHP 秒级定时任务
- thinkphp6集成gatewayWorker(workerman)实现实时监听
- thinkphp6按月新增数据表
- 使用redis 实现消息队列
- api接口 统一结果返回处理类
- 使用swoole+thinkphp6.0+redis 结合开发的登录模块
- 给接口api做签名验证
- ThinkPHP6.0 + UniApp 实现小程序的 微信登录
- ThinkPHP6.0 + Vue + ElementUI + axios 的环境安装到实现 CURD 操作!
- 异常$e
- 参数请求验证自定义和异常错误自定义