Vue 文本超過三行展示省略號秽褒,并加上展開和收起的功能

場景:在vue項目中文本超過三行展示省略號,并加上展開和收起的功能

在處理多行文本時威兜,經(jīng)常會遇到各種各樣的需求销斟,比如至多展示三行,多余的部分不展示并以省略號結(jié)尾椒舵;又比如在這個基礎(chǔ)上加上一個展開和收起的功能蚂踊。同時UI的展示上還要求和文本本身的位置相對應(yīng)斜做。

具體實現(xiàn)思路如下:

  • 1箭启、判斷當前內(nèi)容是否超過三行知市。此處可以給每行設(shè)置一個行高line-height,渲染完后超過三倍的行高即認為是內(nèi)容超過了三行蟹瘾。

  • 2撵枢、展示/收起狀態(tài)的切換可以通過data中的參數(shù)來綁定

  • 3择份、在底部使用position:absolute來絕對定位展開該在的位置狸吞。

  • 4胆描、根據(jù)業(yè)務(wù)需求來設(shè)定好展開和收起按鈕需要呆的地方炬灭。

其中需要注意的點有

  • 展開收起按鈕的高度和行高要和原來文本的行高一致醋粟,不然會導(dǎo)致樣式不統(tǒng)一。

  • 獲取文本的高度時要注意使用this.$nextTick()來保證DOM渲染完成后再獲取高度

  • 在不同場景下省略號可能不能夠完全遮住最后幾個字重归,可以通過調(diào)節(jié)空格米愿,字體排布方式等辦法來調(diào)整,或者不要把展開和文本放在同一行鼻吮,另起一行并且在末尾打開省略文本的樣式

下面是我在日常迭代中寫的一個比較簡單的三行展示省略號并帶有展開收起功能的小例子育苟。歡迎大佬們指正~

先上具體實現(xiàn)代碼:

DOM

<template>
    <div class="content-wrap">
        <div :class="['content', expande ? 'expande' : 'close']" ref="content">
            思路:1、判斷當前內(nèi)容是否超過三行椎木。此處可以給每行設(shè)置一個行高line-height,渲染完后超過三倍的行高即認為是內(nèi)容超過了三行宙搬。2笨腥、展示/收起狀態(tài)的切換可以通過data中的參數(shù)來綁定。3勇垛、在底部使用position:absolute來絕對定位展開該在的位置脖母。4、根據(jù)業(yè)務(wù)需求來設(shè)定好展開和收起按鈕需要呆的地方闲孤。
        </div>
        <div
            class="expande-button-wrap"
            v-if="needShowExpande"
        >
            <div class="expande-button" @click="expandeClick" v-if="!expande">
                <span style="color: black">...</span> 展開
            </div>
            <div class="expande-button" @click="expandeClick" v-else>收起</div>
        </div>
    </div>
</template>

Style

<script>
export default {
    name: 'App',
    data() {
        return {
            expande: true,
            needShowExpande: false,
        }
    },
    methods: {
        expandeClick() {
            console.log('expandeClick')
            this.expande = !this.expande
        },
    },
    mounted() {
        this.$nextTick(() => {
            let lineHeight = 22
            if (this.$refs.content.offsetHeight > lineHeight * 3) {
                this.expande = false
                this.needShowExpande = true
            } else {
                this.expande = true
            }
        })
    },
}
</script>

Script

<style >
.content {
    font-size: 14px;
    color: black;
    letter-spacing: 0;
    line-height: 22px;
    text-align: justify;
    overflow: hidden;
    /* display: -webkit-box; */
    /* -webkit-line-clamp: 3;
    -webkit-box-orient: vertical; */
    /* text-overflow: ellipsis; */
}

.expande {
    overflow: auto;
    height: auto;
    padding-bottom: 22px;
}

.close {
    overflow: hidden;
    height: 66px;
    padding-bottom: 0;
}

.expande-button-wrap {
    position: absolute;
    bottom: 0;
    right: 0;
    height: 22px;
    background: white;
}

.expande-button {
    text-align: right;
    vertical-align: middle;
    color: #5995ef;
    font-size: 14px;
    line-height: 22px;
}
</style>


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末谆级,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子讼积,更是在濱河造成了極大的恐慌肥照,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件勤众,死亡現(xiàn)場離奇詭異舆绎,居然都是意外死亡,警方通過查閱死者的電腦和手機们颜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門吕朵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人窥突,你說我怎么就攤上這事努溃。” “怎么了阻问?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵梧税,是天一觀的道長。 經(jīng)常有香客問我称近,道長第队,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任刨秆,我火速辦了婚禮凳谦,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘坛善。我一直安慰自己晾蜘,他們只是感情好邻眷,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布眠屎。 她就那樣靜靜地躺著,像睡著了一般肆饶。 火紅的嫁衣襯著肌膚如雪改衩。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天驯镊,我揣著相機與錄音葫督,去河邊找鬼竭鞍。 笑死,一個胖子當著我的面吹牛橄镜,可吹牛的內(nèi)容都是我干的偎快。 我是一名探鬼主播,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼洽胶,長吁一口氣:“原來是場噩夢啊……” “哼晒夹!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起姊氓,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤丐怯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后翔横,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體读跷,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年禾唁,在試婚紗的時候發(fā)現(xiàn)自己被綠了效览。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡蟀俊,死狀恐怖钦铺,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情肢预,我是刑警寧澤矛洞,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站烫映,受9級特大地震影響沼本,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜锭沟,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一抽兆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧族淮,春花似錦辫红、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蝙斜,卻和暖如春名惩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背孕荠。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工娩鹉, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留攻谁,地道東北人。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓弯予,卻偏偏與公主長得像戚宦,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子锈嫩,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內(nèi)容