JavaScript實現(xiàn)文字展開和收起效果
列表式的文字的展開和收起的實現(xiàn),供大家參考,具體內(nèi)容如下
需求:
1、當文字超出目標值,則截取目標值,其他隱藏,同時顯示“展開”二字和下拉箭頭;
2、點擊“展開”顯示所有文字,同時改為“收起”和上拉箭頭
3、如果文字本身就沒有超過目標值,則顯示所有文字即可
之前想過使用css設置超出多少行隱藏,或者給Li標簽設置高度隱藏,但都無法滿足以上第三條,所以想到了下邊一種方法將就可以使用
思路:
1、初始遍歷需要展開和收起的元素,超出目標值隱藏,然后把所有標簽中的內(nèi)容存起來(后邊顯示全部的時候會用到)
2、點擊展開和收起的時候,根據(jù)當前的內(nèi)容去存儲的值中匹配,匹配到之后做相應的處理,展示出來
HTML
<ul class="outList"> <li> <div>5-14號</div> <ul class="innerList"> <li class="wordsContent">111111111111111111111111</li> <li class="wordsContent">222222222222222222222222</li> <li class="wordsContent">333333333333333333333333</li> </ul> </li> <li> <div>5-15號</div> <ul class="innerList"> <li class="wordsContent">4444</li> <li class="wordsContent">5555555555555555555555555</li> <li class="wordsContent">6666666666666666666666666</li> </ul> </li> </ul>
CSS
ul,li { list-style: none; } .innerList>li { margin-bottom: 0.2rem; border-bottom: 0.01rem solid green; box-sizing: border-box; padding: 0.2rem 5% 0.7rem 3%; position: relative; margin-bottom: 0.3rem; } .open { font-size: 0.22rem; color: #12309E; position: absolute; right: 0.2rem; bottom: 0.1rem; font-weight: bold; } .close { font-size: 0.22rem; color: #12309E; position: absolute; right: 0.2rem; bottom: 0.1rem; font-weight: bold; }
JS
//新聞的展開收起部分 var objList = $(".wordsContent"); //需要展開收起的li標簽元素 var maxNum = 5; //目標值的長度 var arr = []; //需要展開收起的所有文字匯總 objList.delegate(".open", "click", function () { openClose(true, this) }) objList.delegate(".close", "click", function () { openClose(false, this) }) //初始化封裝,初始化是為了1:存儲原本的Li標簽中的內(nèi)容;2:超出目標值的文字隱藏 function init(objList, maxNum) { objList.each(function (index, item) { arr.push($(item_).text()) if ($(item).text().length > maxNum) { $(item).html($(item).text().substr(0, maxNum) + "<span class='open'>展開<img src='./image/down^.png'/></span>") } }) } init(objList, maxNum) //展開和收起的封裝 function openClose(boo, clickObj) { var final = ''; arr.map(function (item, index) { if (item.match($(clickObj).parents(".wordsContent").text().substring(0, $(clickObj).parents(".wordsContent").text().length - 2))) { final = item } }) if (boo) { $(clickObj).parents(".wordsContent").html(final + "<span class='close'>收起<img src='./image/up^.png'/></span>") } else { $(clickObj).parents(".wordsContent").html(final.substr(0, maxNum) + "<span class='open'>展開<img src='./image/down^.png'/></span>") } }
效果
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JAVASCRIPT style 中visibility和display之間的區(qū)別
visibility屬性用來確定元素是顯示還是隱藏的,這用visibility="visible|hidden"來表示(visible表示顯示,hidden表示隱藏)。2010-01-01微信小程序+騰訊地圖開發(fā)實現(xiàn)路徑規(guī)劃繪制
這篇文章主要介紹了微信小程序+騰訊地圖開發(fā)實現(xiàn)路徑規(guī)劃繪制,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-05-05頁面js遇到亂碼問題的解決方法是和無法轉(zhuǎn)碼的情況
在老項目里加些js文件和老項目的編碼格式不一致出現(xiàn)亂碼,由于兩個文件都不能轉(zhuǎn)格式,于是百度個不錯的方法在此與大家分享下2014-04-04JavaScript如何實現(xiàn)防止重復的網(wǎng)絡請求的示例
這篇文章主要介紹了JavaScript如何實現(xiàn)防止重復的網(wǎng)絡請求的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01