国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

Layui之table中的radio在切換分頁(yè)時(shí)無(wú)法記住選中狀態(tài)的解決方法

2019-11-19 10:55:17
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

情景描述

Layui數(shù)據(jù)表格中用到了表單元素radio,在當(dāng)前頁(yè)面選中radio狀態(tài),并同步更新到保存表格中所有的數(shù)據(jù)的數(shù)組中(獲取表格中的所有數(shù)據(jù)并保存到數(shù)組中),再點(diǎn)擊分頁(yè)組件中的下一頁(yè)、上一頁(yè)、跳轉(zhuǎn)按鈕進(jìn)行切換另外一個(gè)頁(yè)面,然后在切換回之前的頁(yè)面,會(huì)發(fā)現(xiàn)在以前頁(yè)面上radio狀態(tài)全部恢復(fù)默認(rèn)了,我們當(dāng)然是希望能保存住前一頁(yè)radio的選中狀態(tài)。

我寫(xiě)項(xiàng)目遇到的一個(gè)的情況:在第一頁(yè)選中的radio的狀態(tài),點(diǎn)擊下一頁(yè)按鈕切換到第二頁(yè),然后再點(diǎn)擊上一頁(yè)切換會(huì)第一頁(yè),第一頁(yè)中的radio狀態(tài)就恢復(fù)默認(rèn)了。

原因分析

點(diǎn)擊分頁(yè)組件中的小組件進(jìn)行切換頁(yè)面時(shí),渲染切換到的目標(biāo)頁(yè)面所使用的數(shù)據(jù)并不是更新后的tableContent中的數(shù)據(jù),而是使用的table模塊緩存中的數(shù)據(jù),而我們只更新完tableContent中的數(shù)據(jù)時(shí)它并不會(huì)同步更新table模塊緩存中的數(shù)據(jù),所以導(dǎo)致了切換頁(yè)面的時(shí)候無(wú)法記住radio的狀態(tài)。

解決辦法

弄清楚問(wèn)題原因解決起來(lái)就很簡(jiǎn)單了,只需要再點(diǎn)擊radio的時(shí)候,同步更新tableContent中的數(shù)據(jù)和table模塊緩存中的數(shù)據(jù)就可以了(數(shù)據(jù)是放在table的cache屬性中的,如下圖)。

數(shù)據(jù)表格

table中的數(shù)據(jù)

代碼

layui.use(['form','layer','element','table','laypage'],function(){ var form = layui.form; var layer = layui.layer; var element = layui.element; var table = layui.table; var laypage = layui.laypage; // 存儲(chǔ)數(shù)據(jù)表格中的原始數(shù)據(jù)也就是索引鍵信息 var tableContent = new Array(); // 監(jiān)聽(tīng)數(shù)據(jù)表格中的radio,更新原始數(shù)據(jù)數(shù)據(jù)中的radio狀態(tài),同時(shí)更新數(shù)據(jù)表格的緩存 form.on('radio(sortRadio)',function(data){ console.log(data); console.log(data.elem); //得到radio原始DOM對(duì)象 console.log(data.value); //被點(diǎn)擊的radio的value值 var radioValue = data.value; // 獲取customId var radioName = $(data.elem).attr('name'); var tempArr = radioName.split('-'); var customId = parseInt(tempArr[1]); console.table(tableContent); // 將選擇的排序方式更新到原始數(shù)據(jù)數(shù)組中 $.each(tableContent,function(index,data){  if (data.customId === customId) {   data.indexOrder = radioValue;  } }); console.log(table); console.table(tableContent); // 更新緩存中的排序方式 var cacheData = table.cache.indexKeyTable; $.each(cacheData,function(index,data){  if (data.customId === customId) {   data.indexOrder = radioValue;  } }); console.table(table.cache.indexKeyTable); });})

以上這篇Layui之table中的radio在切換分頁(yè)時(shí)無(wú)法記住選中狀態(tài)的解決方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 云龙县| 汉阴县| 德保县| 富源县| 乌兰县| 玛多县| 拉孜县| 马山县| 精河县| 高邮市| 胶南市| 合水县| 辽宁省| 隆安县| 修水县| 安徽省| 凤凰县| 南靖县| 沽源县| 司法| 麻栗坡县| 醴陵市| 荣成市| 图片| 大关县| 肥西县| 来安县| 辽源市| 洞头县| 江口县| 页游| 巧家县| 勐海县| 余江县| 康平县| 班戈县| 汾西县| 桃江县| 灌阳县| 广德县| 朔州市|