1.單選按鈕必須要有一項被選中,才可以取到值,否則值是undefined,單選按鈕必須取相同的name才能有單選效果.編輯模態框時
```
$('input\[value="'+data.field+'"\]').prop('checked',true);
```
注意:遇到此問題時極容易被attr()方法坑.prop是attr缺陷的補充,主要適用屬性值一更改,就立馬生效的.如
??
2\. 在vue的實力外部獲取和賦值實例的data成員,可以通過如下方式獲取,假如var app = new Vue(\[\]);
則? app.\_data.field用來對field進行取值和賦值
3.jquery的表單serialize()方法默認對參數進行了encodeURIComponent,會導致中文亂碼.還原的話,解碼即可
```
var params = $('#DialogForm').serialize();
params = decodeURIComponent(params,true);
var params = parse\_query\_str(params);
```
4.vedio標簽.初始化只顯示指定大小寬高,播放開始顯示資源本身寬高,結束又恢復指定寬高
您的瀏覽器不支持html標簽video,請更換更先進的瀏覽器,以提供更好的體驗
5.避免表單輸入框focus時自動提示歷史輸入記錄,可以在input加屬性autocomplete="off" on是開啟
6.訂單表關聯買賣雙方以及買賣物的固有屬性,可作為冗余字段加入訂單表,變化屬性經由主鍵ID關聯查詢
7.checkbox全選與反選
```
? ? ?\* @remark? 全選
? ? $('#all\_choose').click(function(){
? ? ? ? $('.checkAll').prop('checked', true);
? ? ? ? $('.check').prop('checked', true);
? ? })
? ? ?\* @remark? 反選
? ? $('#rev\_choose').click(function(){
? ? ? ? $('.checkAll').prop('checked', !$('.checkAll').prop('checked'));
? ? ? ? $('.check').each(function(){
? ? ? ? ? ? $(this).prop('checked', !$(this).prop('checked'));
? ? ? ? })
? ? })
? ? ?\* @remark? 一鍵全選/全不選
? ? $('.checkAll').click(function(){
? ? ? ? $('.check').prop('checked', $('.checkAll').prop('checked'));
? ? })
```
8.在iframe結構的后臺里,子窗口登錄超時,只在子窗口顯示登陸界面,外部iframe依然顯示,不合理。應整個瀏覽器刷新為登錄頁面
```
// 檢測登錄界面是否有上級窗口,判斷窗口地址是否相同.如果不同,刷新頂部窗口為登錄
? ? ? ? if(window.top.location.href!=location.href)? ? ??
? ? ? ? {? ? ? ??
? ? ? ? ? ? window.top.location.href=location.href;? ? ??
? ? ? ? }
改代碼僅放在登錄頁面頁面剛加載完執行js處?
```
9.設置iframe的邊框與父窗口或瀏覽器窗口邊框進行分離進而設置padding和margin屬性。添加iframe樣式box-sizing: border-box;否則有邊框會與父邊框貼合在一起
10.如果導出的數據庫備份為.psc文件,恢復備份先打開navicat,連接本地服務器,打開數據庫,右擊備份選項,點擊恢復備份,選擇備份文件,確定恢復
11.置頂功能,通常在列表的操作列有置頂按鈕,設置該記錄排序字段值變為最高,同時所有其他字段減1,在order里令排序字段為第一位,這樣可以保證置頂記錄排序值最高且唯一.另外行記錄里排序字段可以支持直接修改.效果可以是點擊切換輸入框,或直接顯示輸入框.使用change事件.聲明一個全局舊值默認為0,開始修改時記錄舊值,修改后進行合法性等各種規則校驗,移出光標進行校驗及提交,成功刷新列表,失敗還原舊值,并使全局舊值變量重置為0
12.php導出報表,如果數據數字很長,如身份證,銀行卡類似的可能會導致導出的數據是科學計數法,不符合期待.如果想讓他完整顯示.在數據后拼一個換行符使其成為一個字符串就可以了,如下
$var = $var."\\t";
13.動態生成dom時,jquery綁定事件不生效.綁定事件在頁面初始化時會進行注冊,如果此時沒有dom,則事件失效即使后面動態生成.可以通過給父元素添加監聽事件,$(parent\_element).on('event', 'children\_element', function(){響應操作});
實現省市區三級聯動時遇到此問題.
14.表格內容過長而變形的解決方法。
在表格加入如下屬性設置:
```
style="TABLE-LAYOUT:fixed;WORD-WRAP:break\_word"
```
上面顯示有超過表格長度的自動截取。
如果要表格長度固定,且超過長度時自動換行,則:
```
style="TABLE-LAYOUT:fixed;WORD-BREAK:break-all"
```
此處切勿設置tr 或td的高度
15.ajax提交帶有文件上傳的表單.
// 從表單直接獲取要提交的數據
```
var form = new FormData(document.getElementById("act\_form"));
????????? ? //??自定義補充其他數據
? ? ? ? ? ? form.append('operation', 'add\_adv');
? ? ? ? ? ? form.append('type\_id', $("#navActive").val());
? ? ? ? ? ? $.ajax({
? ? ? ? ? ? ? ? url: api\_url,
? ? ? ? ? ? ? ? type: "post",
? ? ? ? ? ? ? ? data: form,
? ? ? ? ? ? ? ? processData: false,
? ? ? ? ? ? ? ? contentType: false,
? ? ? ? ? ? ? ? success: function(response){
? ? ? ? ? ? ? ? ? ? if (response.code == 1) {
? ? ? ? ? ? ? ? ? ? ? ? layer.msg(response.msg, function () {});
? ? ? ? ? ? ? ? ? ? ? ? location.href = api\_url;
? ? ? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? ? ? swal(response.msg, {
? ? ? ? ? ? ? ? ? ? ? ? ? ? icon: "warning"
? ? ? ? ? ? ? ? ? ? ? ? });
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? error:function(e){
? ? ? ? ? ? ? ? ? ? swal('請求錯誤', {
? ? ? ? ? ? ? ? ? ? ? ? icon: "warning"
? ? ? ? ? ? ? ? ? ? });
? ? ? ? ? ? ? ? }
? ? ? ? ? ? });?
```
PHP服務端文件要用$\_FILE處理
16.input file? 獲取待上傳文件信息 &&?上傳完文件后把input type為file的文本框的文件信息清除了
JS
```
var test= document.getElementById('test');
var formData = new FormData();
formData.append('version\_file', test.files\[0\]);
var ajax = new XMLHttpRequest();
ajax.open("post", "test.php", true);
ajax.send(formData );
```
JQ
```
var formData = new FormData();
var test = $('#test')\[0\].files\[0\];//或者 $('#test').get(0).files\[0\]);
formData.append('version\_file', test);?
$.Ajax({
type: 'POST',
url: 'test.php',
data:formData,
? ? ? ? cache: false,//上傳文件無需緩存
? ? ? ?processData: false,//用于對data參數進行序列化處理 這里必須false
? ? ? ?contentType: false, //必須
success: function(res){
console.log(res)
}
})
var test = document.getElementById('test');
test.value = '';//雖然test的value不能設為有字符的值,但是可以設置為空值
或
var test = document.getElementById('test');
test.outerHTML = test.outerHTML;? ? ? ? ? ? ? ? //重新初始化了test的html
```
17.獲取上傳圖片寬高
//基于jquery,選的某一個本地文件
```
$('#file').on('change',function () {
? ? ? ? let url = window.URL || window.webkitURL;
? ? ? ? console.log(url.createObjectURL(this.files\[0\]));//this.files\[0\]為選中的文件(索引為0因為是單選一個),這里是圖片
? ? ? ? ? ? let img = new Image();? ? ? ? ? ? ? //手動創建一個Image對象
? ? ? ? ? ? img.src = url.createObjectURL(this.files\[0\]);//創建Image的對象的url
? ? ? ? ? ? img.onload = function () {
? ? ? ? ? ? ? ? console.log('height:'+this.height+'----width:'+this.width)
? ? ? ? ? ? }
? ? });
? $('#file').on('change',function () {
? ? ? ? let reader = new FileReader();
? ? ? ? reader.readAsDataURL(this.files\[0\]);//這里把一個文件用base64編碼,具體什么是base64編碼,我將稍后在不久的文章中介紹
? ? ? ? reader.onload = function(e){
? ? ? ? ? ? let img = new Image();
? ? ? ? ? ? img.src = e.target.result;//獲取編碼后的值,也可以用this.result獲取
? ? ? ? ? ? img.onload = function () {
? ? ? ? ? ? ? ? console.log('height:'+this.height+'----width:'+this.width)
? ? ? ? ? ? }
? ? ? ? }
```
18.動態綁定元素事件,
$("ele").on("event", "child\_ele", function(e, arg1, arg2...){
????? ? //code...
}):
注定出發事件,帶參數
$("child\_ele").trigger("event", \[arg1, arg2\]);
19.前后端分離界面通常使用modal來進行表單提交.而提交后又會有重置表單的需要.這里可以使用表單form的reset方法.
JS: domObj.reset();
JQ: jqObj\[0\].reset();
這里有坑.? 隱藏域 input hidden 并不會被重置? 需要手動重置
- 常見功能
- 第三方授權登錄
- 郵件發送
- 簡易聊天室
- 獲取各國匯率
- PHP獲取服務器硬件指標
- 數據上報之
- web開發
- 開發規范
- 前端
- 踩坑
- 將footer固定在底部
- bootstrap
- Metronic
- 用到的jquery插件
- bootstrap-hover-dropdown
- jquery.slimscroll
- jquery.blockui
- bootstrap-switch
- js.cookie
- moment
- bootstrap-daterangepicker
- morris
- raphael
- jquery.waypoints
- jquery.counterup
- select2
- 取值和設置默認值
- vue
- axios
- 瀏覽器
- 谷歌瀏覽器
- 谷歌插件
- layui
- layui-表格
- layui-表單
- layui-彈窗
- layui-分頁
- 后端
- 操作系統
- linux
- 用戶管理
- 文件管理
- 目錄管理
- 壓縮和解壓縮
- 進程查看
- 端口查看
- 開機自啟動服務
- 定時任務
- shell腳本
- 殺掉運行超過指定時長指定服務的進程
- 獲取服務器使用狀態
- bash-shell連接socket
- 自定義快捷命令
- centos-踩坑
- 防火墻
- 軟件
- yum
- vim
- screen
- window
- 語言
- PHP
- 配置優化
- 框架
- thinkphp5.1+
- think命令行
- laravel6.+
- 維護模式
- 根據環境讀取不同配置
- laravel6.+采坑
- laravel坑位
- 數據庫事務
- 任務調度
- 文件權限問題
- 增強框架
- larvel:elastic-search
- 圖形驗證碼
- laravel獲取ip
- 函數
- strtotime
- 正則匹配
- 類
- 接口類與抽象類
- 類相關的關鍵字 - abstract
- 類相關的關鍵字 - interface
- PHP有關類的調用方式"->"與"::"的區別
- 擴展
- 問題歸納
- json_encode和json_decode
- 字符串的運算
- curl
- 優化php效率
- 數組相加合并與array_merge
- 時區轉換
- 不常用特性
- php反射
- 包管理器-composer
- GuzzleHttp
- Python
- Go
- 數據庫
- Redis
- 安裝
- 本地化-數據備份
- php-redis操作
- Mysql
- mysql-命令集合
- 設置終端可訪問
- 數據庫設計
- 用戶基礎信息表
- 踩坑集合
- mysql-2002
- mysql-2054
- 優化策略
- mysql-密碼驗證插件
- 一些牛逼的sql查詢
- topN
- 無限級分類
- Memcache
- MongoDb
- 安裝mongo-server
- 安裝php-mongodb擴展
- 在laravel中使用mongoDB
- 客戶端軟件
- Hbase
- Elasticsearch
- elastic-search
- restfulApi操作es
- web服務器
- 1.nginx
- 配置語法規則
- 配置詳解
- rewrite規則
- request_filename
- 2.apache
- 功能設計
- 加密解密
- Base64
- 對亞馬遜SKU加密
- 兼職項目中的加解密
- 騰訊外包時的加密
- 接口設計
- 接口限流設計
- 分庫分表
- 遍歷展示文件目錄結構
- 時區換算
- 文件切割
- 解析xml字符串
- 項目
- 博客后臺管理
- 亞馬遜廣告API
- 官方指引文檔
- 開發人員中心
- 應用商店
- 第三方庫
- 申請API郵件記錄
- 亞馬遜MWS
- 付款報告
- 亂碼
- 亞馬遜管理庫存報告
- 報告
- 商品
- 入庫
- 履行
- 出庫
- 財務
- 訂單
- 異步任務處理
- 集群如何同步代碼
- 基本開發流程
- 文檔管理
- showdoc
- 運行環境
- 開發環境
- vagrant
- windows上配置安裝
- vagrant安裝插件緩慢
- 更換ssh默認端口映射
- 設置x-shell密碼登錄
- 使用市場的box-homestead
- homestead-7: Box 'lc/homestead'
- 常見問題
- 虛擬環境reboot
- 突然無法使用
- phpStudy
- wamp
- 壓測性能
- VPN
- vultr
- 凌空圖床
- 寶塔
- 自動化部署
- 版本管理軟件鉤子
- 線上環境-LNMP
- centos7
- nginx
- mysql
- mysql開機自啟
- mysql-更換默認端口
- datetime字段類型默認值
- php
- php擴展安裝
- redis
- swoole
- gd
- BCMath
- igbinary
- zstd
- 包管理器:composer
- 優化性能
- nodejs
- 更新gcc版本
- 版本控制
- git
- 常用命令
- gitlab
- 版本管理規范
- 使用阿里云創建遠程倉庫
- git自動化部署
- svn
- 忽略指定文件
- 拉取代碼
- 自動化運維
- jekins
- 容器
- 集群
- 架構設計
- 設計原則
- 閱讀參考
- 代碼規劃
- 架構實戰
- 服務治理
- 權限控制設計
- 具體設計
- 計劃
- 疑問知識點
- 讀書筆記
- 高性能Mysql
- TCP-IP詳解-卷一:協議
- 思考
- php如何實現并發執行
- 對接調用設計
- 如何在瀏覽器上實現插件
- 如何設計一個app結合業務告警
- mysql的where查詢沒有用到索引
- 為啥in查詢比循環嵌套sql的查詢還要慢
- 使用git來創建屬于自己的composer包
- 翻頁獲取數據的時候又新增了數據
- 安全思路
- 月報
- PHP ?? 和 ?: 的區別
- PHP異步執行
- redis集群的目標是什么
- 大文件數據處理
- 性能瓶頸分析
- 命令行里輸出帶顏色的字體
- 面試問題合集
- 基礎
- 安全
- 算法
- 冒泡排序
- 快速排序
- 二分法查詢數組指定成員
- 字符查找匹配
- 令牌桶
- 漏桶
- 計數器
- 代理
- 協議
- http
- 狀態碼
- tcp
- udp
- Oauth2.0
- 設計模式
- 單例模式
- 適配器模式
- 工廠模式
- 觀察者模式
- 流程化
- 地址欄輸入網址到返回網頁的流程
- 題目收集
- 工具
- rabbitMq
- rabbitMQ用戶管理
- 生產者
- 消費者
- 支持TP5.*的think-queue
- 消息丟失
- 消費者報錯
- rabbitMQ配置優化
- 磁盤滿載導致服務掛掉
- PHP類庫
- rabbitMQ踩坑
- navicat
- vscode
- phpstorm
- 激活碼
- markdown
- PHP自定義類庫
- 工具類
- 領導力
- 任務分配
- 代碼組織
- 不要重復
- 避免污染
- 接口定義規范
- 小業務需求
- 獲取充值面額組成
- 監控服務器CPU和內存
- shell腳本版本