layui使用技巧和常見問題匯總
1.表單重新渲染(處理下拉框未展示問題)
有時候我們在js中進(jìn)行下拉框的動態(tài)初始化,或者我們做聯(lián)動下拉的時候發(fā)現(xiàn)已經(jīng)查詢出數(shù)據(jù)但是下拉框并沒有展示出來,這個時候就需要我們在初始化完成之后或者聯(lián)動數(shù)據(jù)查詢之后對表單進(jìn)行重新渲染,這樣就能加載出來了。
layui.use('form', function(){ // 高版本建議把括號去掉,有的低版本,需要加() var form = layui.form; // 也可以單單初始化下拉框form.render('select'); form.render(); });
可以將方法都封裝在一個變量中,調(diào)用的時候更方便,例如要調(diào)用方法直接寫
commonFuns.renderForm();
// 封裝方法 var commonFuns = { //重新渲染表單 renderForm : function(){ layui.use('form', function(){ //高版本建議把括號去掉,有的低版本,需要加() var form = layui.form; form.render(); }); } };
原因是layui內(nèi)置的Form模塊為全自動渲染,她將原本普通的諸如select、checkbox、radio等元素重置為你所看到的模樣,只要你的頁面對應(yīng)js有像以下定義即可渲染出來
layui.use('form', function(){ var form = layui.form; });
2.下拉框的onchange事件處理
針對下拉框的響應(yīng)事件onchange,在layui中不在select元素直接添加onchange事件,而是在select元素添加一個lay-filter值
<select name="industryType" id="industryType" lay-filter="industryType" > </select>
然后在對應(yīng)的js中對該下拉框元素進(jìn)行監(jiān)聽
// 對表單元素操作比如監(jiān)聽下拉框事件 layui.use(['form'], function(){ var form = layui.form; form.on('select(industryType)', function(data){ // 下拉響應(yīng)事件,和原始的onchange一個效果 commonFuns.industryTypeChange(); // 重新渲染表單 commonFuns.renderForm(); }); });
3.關(guān)閉彈出層,重新加載父頁面
假設(shè)我們需要做一個新增頁面,通過點擊一個新增按鈕彈出一個新頁面,在新的頁面進(jìn)行表單填寫然后保存,我們需要的效果是保存成功后會關(guān)閉當(dāng)前新頁面然后重新加載父頁面。
layer.alert("新增成功!",function(){ // 刷新父頁面 window.parent.location.reload(); // 獲取當(dāng)前彈出層的層級 var index = parent.layer.getFrameIndex(window.name); // 關(guān)閉彈出層 parent.layer.close(index); });
4.父頁面如何傳遞參數(shù)給彈出層的iframe頁面
在頁面處理中經(jīng)常碰到需要彈出一個頁面,比如修改頁面或者查看頁面等,這時候可以用layer.open進(jìn)行操作,如果我們用layer.open打開的是一個iframe頁面,我們該如何將父頁面的一些參數(shù)傳遞過去,有2種方法,第一種直接在url地址后面?zhèn)鲄?,類似于xxx.action?name=xxx,第二種則是在父頁面的js寫一個對象然后給對象賦值
//監(jiān)聽工具條 table.on('tool(viewGrid)', function(obj){ var selectData = obj.data; if(obj.event === 'btnView'){ // 注意下面的param不要在此處加var,否則就限定范圍了,可以直接就按照下面寫 param = { selectData : selectData, type : "view" }; // 頁面層 layer.open({ type: 2, title : '查看詳情', area: ['1000px', '650px'], content: url }); } });
在iframe的子頁面中可以按照以下方式取出傳遞的參數(shù)
<script type="text/javascript"> var selectData = parent.param.selectData; var type = parent.param.type; </script>
5.表單元素處于禁用狀態(tài)
在layui中讓表單元素處于禁止?fàn)顟B(tài),加上disabled即可,但是為了效果更加明顯,我們可以在元素上加上一個內(nèi)置class樣式名稱layui-disabled,加上這個樣式會有禁止的圖標(biāo)出現(xiàn)
<input type="text" id="addrName" name="addrName" class="layui-input layui-disabled" disabled/>
6.表單提交如何獲取表單元素值集合
要獲取表單元素的值的集合,需要注意以下幾點
第一要在表單提交的按鈕元素上加上lay-submit以及l(fā)ay-filter
<button class="layui-btn layui-btn-normal" data-type="btnSave" id="btnSave" lay-submit lay-filter="btnSave">保存</button>
第二在表單的各個元素都必須要有name元素,不然獲取不到該元素的值
<input type="text" id="notes" name="notes" class="layui-input" />
表單監(jiān)聽事件得到表單元素值集合
btnSave : function(){ // 監(jiān)聽表單提交 form.on('submit(btnSave)', function(data){ var formVal = data.field; console.log(formVal); }); }
以上submit后面括號中的值對應(yīng)前面按鈕中的lay-filter中的值
7.數(shù)據(jù)表格固定列
在表格中針對某一行,我們需要對該行進(jìn)行操作,比如查看或者修改,這個時候我們需要固定一列作為操作列來放置按鈕
首先在jsp頁面的中寫入按鈕,一般選擇放在body結(jié)束前,在script中寫一個id
<script type="text/html" id="barDemo"> <a class="layui-btn layui-btn-primary layui-btn-xs" lay-event="btnEdit">編輯</a> </script> </body> </html>
然后在js的表格渲染中的cols最后加上以下代碼
{field:'wealth', title: '操作',fixed: 'right', width:100, align:'center', toolbar: '#barDemo'}
其中toolbar為前面寫的id元素,fixed表示固定位置
在按鈕中有個lay-event元素,可以用來表格工具條監(jiān)聽
//監(jiān)聽工具條 table.on('tool(viewGrid)', function(obj){ // 該行的數(shù)據(jù) var selectData = obj.data; if(obj.event === 'btnEdit'){ console.log(selectData); } });
8.帶搜索的下拉框
<select name="city" lay-verify="" lay-search> <option value="010">layer</option> <option value="021">form</option> <option value="0571" selected>layim</option> …… </select>
設(shè)定屬性 lay-search 來開啟搜索匹配功能
9.表單提交阻止頁面跳轉(zhuǎn)
form.on('submit(*)', function(data){ console.log(data.elem) //被執(zhí)行事件的元素DOM對象,一般為button對象 console.log(data.form) //被執(zhí)行提交的form對象,一般在存在form標(biāo)簽時才會返回 console.log(data.field) //當(dāng)前容器的全部表單字段,名值對形式:{name: value} return false; //阻止表單跳轉(zhuǎn)。如果需要表單跳轉(zhuǎn),去掉這段即可。 });
在監(jiān)聽表單提交最后加上return false,不能只寫return
10.父頁面如何得到子窗口傳遞回來的值
原理:在父頁面的相關(guān)js中定義一個對象,然后在子頁面對這個對象進(jìn)行賦值,然后在父頁面的相關(guān)打開彈框的js中的頁面銷毀時取得這個值進(jìn)行操作即可
父頁面部分js
// 頁面層 window.returnVal = new Object(); layer.open({ type: 2, title : "測試頁面" , area: ['1200px', '700px'], content: url, end : function (){ var returnVal = window.returnVal; console.log(returnVal); } });
子頁面操作
btnOk : function(){ var item = new Object(); item.name = "測試"; item.type = "okType"; window.parent.returnVal = item; var index = parent.layer.getFrameIndex(window.name); // 關(guān)閉彈出層 parent.layer.close(index); }
11.關(guān)于復(fù)選框獲取的注意事項
方法一:
https://www.layui.com/demo/table/operate.html
簡單總結(jié)
var checkStatus = table.checkStatus('viewGrid'); var checkData = checkStatus.data; if(checkData.length == 0){ layer.alert('請至少選中一條記錄進(jìn)行刪除'); return false; } var checkIds =new Array(); for(var i=0;i<checkData.length;i++){ checkIds.push(checkData[i].XX_ID); }
方法二:
先定義2個數(shù)組,分別存放復(fù)選框的id和當(dāng)前頁的數(shù)據(jù)
// 記錄選中的數(shù)據(jù) var checkIds =new Array(); // 當(dāng)前表格中的全部數(shù)據(jù) var table_data=new Array();
然后監(jiān)聽表格復(fù)選框
//監(jiān)聽表格復(fù)選框選擇,以下XXX_ID為表格記錄的主鍵id,按實際情況來 table.on('checkbox(viewGrid)', function(obj){ if(obj.checked==true){ if(obj.type=='one'){ checkIds.push(obj.data.XXX_ID); }else{ for(var i=0;i<table_data.length;i++){ checkIds.push(table_data[i].XXX_ID); } } }else{ if(obj.type=='one'){ for(var i=0;i<checkIds.length;i++){ if(checkIds[i]==obj.data.XXX_ID){ checkIds.splice(i,1); } } }else{ // 清空 checkIds = new Array(); } } // 去重 checkIds = commonFuns.uniqueArray(checkIds); });
數(shù)組去重方法
// 數(shù)組去重 uniqueArray : function (arr){ var res = []; for(var i=0; i<arr.length; i++){ if(res.indexOf(arr[i]) == -1){ res.push(arr[i]); } } return res; }
然后要注意的是在表格初始化和表格重載(查詢)時需要清空復(fù)選框以及重新給表格數(shù)據(jù)賦值
表格初始化
table.render({ elem: '#viewGrid', url: realUrl, method:'post', where:{queryParams : JSON.stringify(queryParams)}, cols: cols, page: { limit:10, limits:[10,100, 150, 200] }, height:450, id : 'viewGrid', done:function(res,curr,count){ checkIds = new Array(); table_data = res.data; // 返回數(shù)據(jù)關(guān)閉loading layer.close(index); } });
表格重載
// 查詢 btnQuery : function(){ var queryParams = selfFuns.initQueryParams(); var index = layer.load(1, {shade: [0.3, '#000'] });//數(shù)據(jù)加載設(shè)置背景顏色 //執(zhí)行重載 table.reload('viewGrid', { where:{queryParams : JSON.stringify(queryParams)}, page: { curr: 1 //重新從第 1 頁開始 }, done:function (res) { // 清空復(fù)選框 checkIds = new Array(); table_data = res.data; //返回數(shù)據(jù)關(guān)閉loading layer.close(index); } }); }
到此這篇關(guān)于layui使用技巧和常見問題匯總的文章就介紹到這了,更多相關(guān)layui使用技巧內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何通過遞歸方法實現(xiàn)用json-diff渲染json字符串對比結(jié)果
JsonDiff是一個高性能json差異發(fā)現(xiàn)工具,它幾乎可以發(fā)現(xiàn)任何JSON結(jié)構(gòu)的差異,并且將錯誤信息反饋給用戶,下面這篇文章主要給大家介紹了關(guān)于如何通過遞歸方法實現(xiàn)用json-diff渲染json字符串對比結(jié)果的相關(guān)資料,需要的朋友可以參考下2022-12-12element中el-switch的v-model自定義值的實現(xiàn)
在el-switch中設(shè)置active-value和inactive-value屬性,接受Boolean, String或Number類型的值,本文就來介紹一下element中el-switch的v-model自定義值的實現(xiàn),感興趣的可以了解一下2023-11-11微信小程序?qū)崿F(xiàn)地區(qū)選擇偽五級聯(lián)動
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)地區(qū)選擇偽五級聯(lián)動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07