# 后端(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
- 參數請求驗證自定義和異常錯誤自定義