javascript - 通過localStorage實(shí)現(xiàn)表格點(diǎn)擊行置頂 且刷新頁面保持當(dāng)前狀態(tài)
問題描述
由于至少需要3列的值可以確定唯一的行
所以我的思路是 1.每次點(diǎn)擊置頂按鈕的時(shí)候 將對(duì)應(yīng)行的那3列(每列為1個(gè)key)的value存入localStorage,即save過程2.每次重新載入頁面時(shí),讀取本地?cái)?shù)據(jù),在獲取表格數(shù)據(jù)之后,每行的那3列都與存在本地?cái)?shù)據(jù)對(duì)比,相等的就保持置頂
如上的想法,現(xiàn)在我的問題所在:多次點(diǎn)擊之后,每個(gè)列所對(duì)應(yīng)的key的value應(yīng)該不止一個(gè) 對(duì)比該如何進(jìn)行for循環(huán)不太清楚具體用法
問題解答
回答1:其實(shí)你不用每列為一個(gè)Key存儲(chǔ)的,可以將這三列的數(shù)據(jù)做成一個(gè)JS對(duì)象,然后,將字符串化的值存入localStorage,比如:
var col_identifier = { col1: ... col2: ... col3: ...};localStorage.setItem(’col_identifier’, JSON.stringify(col_identifier));
用的時(shí)候直接取出這個(gè)值,然后解析,再取出col1、col2和col3的值,進(jìn)行比對(duì)
var col_identifier = JSON.parse(localStorage.getItem(’col_identifier’) || ’{}’);var col1 = col_identifier.col1 || ’’;var col2 = col_identifier.col2 || ’’;var col3 = col_identifier.col3 || ’’;... // 下面就是對(duì)比表格數(shù)據(jù)了回答2:
可以置頂多個(gè)行嗎?是的話可以存一個(gè)數(shù)組。
感覺比較3個(gè)屬性過于復(fù)雜了,可以給每行一個(gè)唯一的 id,這樣只要看 id 是否匹配就可以。
相關(guān)文章:
1. golang - 用IDE看docker源碼時(shí)的小問題2. html - css氣泡,實(shí)現(xiàn)“倒三角(不知道算不算三角了)”可透明的。3. phpstudy8.1沒集成mysql-front4. java - 如何點(diǎn)擊按鈕,重新運(yùn)行(我是初學(xué)者)?5. 運(yùn)行python程序時(shí)出現(xiàn)“應(yīng)用程序發(fā)生異常”的內(nèi)存錯(cuò)誤?6. 我何時(shí)應(yīng)該在Java中使用JFrame.add(component)和JFrame.getContentPane()。add(component)7. 利用IPMI遠(yuǎn)程安裝centos報(bào)錯(cuò)!8. 前端 - @media query 使用出現(xiàn)的問題?9. html5和Flash對(duì)抗是什么情況?10. javascript - 請(qǐng)指條明路,angular的$event,在select中卻是undefined?

網(wǎng)公網(wǎng)安備