欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年09月02日 16:14:53   作者:xcmercy  
今天小編就為大家分享一篇Layui之table中的radio在切換分頁(yè)時(shí)無(wú)法記住選中狀態(tài)的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

情景描述

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è)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • ES6 對(duì)象的新功能與解構(gòu)賦值介紹

    ES6 對(duì)象的新功能與解構(gòu)賦值介紹

    這篇文章主要介紹了ES6 對(duì)象的新功能與解構(gòu)賦值介紹,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • 其實(shí)你可以少寫(xiě)點(diǎn)if else與switch(推薦)

    其實(shí)你可以少寫(xiě)點(diǎn)if else與switch(推薦)

    switch case與if else的區(qū)別:switch case會(huì)生成一個(gè)跳轉(zhuǎn)表來(lái)指示實(shí)際的case分支的地址,而if...else卻需要遍歷條件分支直到命中條件,下面這篇文章主要給大家介紹了關(guān)于if else與switch在使用中的一些技巧,需要的朋友可以參考下
    2019-01-01
  • 基于JavaScript實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue

    基于JavaScript實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue

    這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-09-09
  • 利用JavaScript編寫(xiě)Python內(nèi)置函數(shù)查詢工具

    利用JavaScript編寫(xiě)Python內(nèi)置函數(shù)查詢工具

    Python有豐富的內(nèi)置函數(shù)實(shí)現(xiàn)各種功能,但查詢內(nèi)置函數(shù)時(shí)總是需要百度查,有沒(méi)有一個(gè)小工具可以單機(jī)無(wú)網(wǎng)絡(luò)查詢Python內(nèi)置函數(shù),方便自己學(xué)習(xí)編寫(xiě)Python程序呢?本文就來(lái)用JavaScript編寫(xiě)一個(gè)
    2023-02-02
  • JavaScript?函數(shù)表達(dá)式與函數(shù)聲明的用法及區(qū)別

    JavaScript?函數(shù)表達(dá)式與函數(shù)聲明的用法及區(qū)別

    這篇文章主要介紹了JavaScript?函數(shù)表達(dá)式與函數(shù)聲明詳析,函數(shù)表達(dá)式和函數(shù)聲明是JavaScript中創(chuàng)建函數(shù)的兩種方法,下面文章具體的相關(guān)內(nèi)容介紹,需要的小伙伴可以參考一下
    2022-06-06
  • 解決微信內(nèi)置瀏覽器返回上一頁(yè)強(qiáng)制刷新問(wèn)題方法

    解決微信內(nèi)置瀏覽器返回上一頁(yè)強(qiáng)制刷新問(wèn)題方法

    微信內(nèi)置瀏覽器在返回上一頁(yè)面,且上一頁(yè)面包含AJAX代碼時(shí),頁(yè)面就會(huì)被強(qiáng)制刷新,極度影響用戶體驗(yàn)。而我們想要的效果是:返回上一頁(yè)面時(shí),頁(yè)面還停留在原來(lái)的狀態(tài),AJAX獲取到的數(shù)據(jù)還在,滾動(dòng)條也在原來(lái)的位置。下面跟著小編一起來(lái)看下吧
    2017-02-02
  • js實(shí)現(xiàn)web調(diào)用攝像頭 js截取視頻畫(huà)面

    js實(shí)現(xiàn)web調(diào)用攝像頭 js截取視頻畫(huà)面

    這篇文章主要為大家詳細(xì)介紹了JS web調(diào)用攝像頭,截取視頻畫(huà)面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • 一文了解TypeScript數(shù)據(jù)類型

    一文了解TypeScript數(shù)據(jù)類型

    本文主要介紹了TypeScript數(shù)據(jù)類型,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07
  • JavaScript顯示當(dāng)前文檔最后修改日期的方法

    JavaScript顯示當(dāng)前文檔最后修改日期的方法

    這篇文章主要介紹了JavaScript顯示當(dāng)前文檔最后修改日期的方法,實(shí)例分析了javascript中document.lastModified的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-03-03
  • 學(xué)習(xí)JavaScript設(shè)計(jì)模式(代理模式)

    學(xué)習(xí)JavaScript設(shè)計(jì)模式(代理模式)

    這篇文章主要帶領(lǐng)大家學(xué)習(xí)JavaScript設(shè)計(jì)模式,其中重點(diǎn)介紹代理模式,對(duì)代理模式進(jìn)行詳細(xì)剖析,感興趣的小伙伴們可以參考一下
    2015-12-12

最新評(píng)論