Vue+jquery實(shí)現(xiàn)表格指定列的文字收縮的示例代碼
本文介紹了Vue+jquery實(shí)現(xiàn)表格指定列的文字收縮的示例代碼,分享給大家,具體如下:

效果很簡(jiǎn)單,但是寫(xiě)起來(lái)真的不容易,因?yàn)閂ue對(duì)于沒(méi)有React這種前端框架經(jīng)驗(yàn)的人是不友好的
(少吐槽,多工作,省下時(shí)間出去hi)
先說(shuō)一下我走過(guò)的彎路:我之間想通過(guò) v-if 指令去操作這一列
代碼是這樣的:
<el-table-column width="250" align="center" label="比較基準(zhǔn)">
<template scope="scope">
<span v-if="isAllTxt">{{getShortStr(scope.row.benchmark)}}</span>
<span v-else>{{scope.row.benchmark}}</span>
<i @click="changeTxt" style="margin-left:8px;color: #20a0ff;" class="el-icon-more"></i>
</template>
</el-table-column>
changeTxt 方法去改變 isAllTxt這個(gè)boolean 從而達(dá)到控制長(zhǎng)短文字的顯示
額,然后每次點(diǎn)擊任意一行,這一列所有的文字都改變了。呃呃呃,這樣產(chǎn)品絕對(duì)不會(huì)答應(yīng)的,你以為是上課全體起立么???
好,我們用原來(lái)jquery時(shí)代開(kāi)發(fā)的經(jīng)驗(yàn),在點(diǎn)擊事件中傳入 $(this) ,手動(dòng)改dom
(前提是項(xiàng)目配置了jquery,請(qǐng)轉(zhuǎn)頭看:http://chabaoo.cn/article/115161.htm,上去,自己動(dòng)。哦不,自己動(dòng)手把它配好)
changeTxt($(this))
changeTxt(ref) {
ref.text(XXX);
}
結(jié)果當(dāng)然是錯(cuò)誤:

那底下就有同學(xué)說(shuō)是不是jquery導(dǎo)錯(cuò)了???
當(dāng)然也不是,這里的 this 并不是 dom 的 this,是vue的vm對(duì)象,不信的可以在方法中用jquery的 $ 試一下,并不是jquery的鍋。
那又有愛(ài)思考的小伙伴說(shuō)我用直接用 this 可以么 ?
changeTxt(this)

得到的并不是當(dāng)前元素的對(duì)象,這條路又不通。
那vue中是怎么得到元素的對(duì)象的呢???
給元素定義 ref
<span ref="txt">{{getShortStr(scope.row.benchmark)}}</span>
方法中通過(guò) this.$refs['txt'].text(XXX) 改變dom,嗯?

引用返回的是什么 ??? 沒(méi)法操作啊 ,而且返回的這個(gè)標(biāo)簽是表格最后一行的數(shù)據(jù),哇,亂七八糟,爆炸。
無(wú)奈,只能通過(guò)最笨的方法,給我們的 span 定義 id ,而且是不同的 id ,用 jquery 獲取 id 對(duì)應(yīng)的元素
<el-table-column width="250" align="center" label="比較基準(zhǔn)">
<template scope="scope">
<span :id="scope.row.id">{{getShortStr(scope.row.benchmark)}}</span>
<i v-if="scope.row.benchmark.length>20" @click="changeTxt(scope.row.benchmark,scope.row.id)" style="margin-left:8px;color: #20a0ff;" class="el-icon-more">
</i>
</template>
</el-table-column>
// changeTxt方法:
changeTxt(txt,id) {
this.isAllTxt = !this.isAllTxt;
if(this.isAllTxt){
$('#'+id).text(txt);
}else{
$('#'+id).text(this.getShortStr(txt));
}
}
// getShortStr 方法
getShortStr(txt_origin) {
if(txt_origin.length > 20){
return txt_origin.substring(0,20);
}else{
return txt_origin;
}
}
搞定是搞定了,但是 jquery 和 vue 的風(fēng)格是不一樣的,混用體驗(yàn)并不是很好,有好的方法請(qǐng)一定留言告訴我,必定送上一句 謝謝 ?。?!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue中實(shí)現(xiàn)滾動(dòng)加載與無(wú)限滾動(dòng)
本文主要介紹了Vue中實(shí)現(xiàn)滾動(dòng)加載與無(wú)限滾動(dòng),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
詳解nginx配置vue h5 history去除#號(hào)
這篇文章主要介紹了詳解nginx配置vue h5 history去除#號(hào),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
window.onresize在vue中只能使用一次,自適應(yīng)resize報(bào)錯(cuò)問(wèn)題
這篇文章主要介紹了window.onresize在vue中只能使用一次,自適應(yīng)resize報(bào)錯(cuò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
使用vue2.6實(shí)現(xiàn)抖音【時(shí)間輪盤(pán)】屏保效果附源碼
前段時(shí)間看抖音,有人用時(shí)間輪盤(pán)作為動(dòng)態(tài)的桌面壁紙,一時(shí)間成為全網(wǎng)最火的電腦屏保,后來(lái)小米等運(yùn)用市場(chǎng)也出現(xiàn)了【時(shí)間輪盤(pán)】,有點(diǎn)像五行八卦,感覺(jué)很好玩,于是突發(fā)奇想,自己寫(xiě)一個(gè)網(wǎng)頁(yè)版小DEMO玩玩,需要的朋友可以參考下2019-04-04
手寫(xiě)Vue內(nèi)置組件component的實(shí)現(xiàn)示例
本文主要介紹了手寫(xiě)Vue內(nèi)置組件component的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
Vue實(shí)現(xiàn)可移動(dòng)水平時(shí)間軸
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)可移動(dòng)水平時(shí)間軸,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06
Vue編寫(xiě)可顯示周和月模式的日歷 Vue自定義日歷內(nèi)容的顯示
這篇文章主要為大家詳細(xì)介紹了Vue編寫(xiě)可顯示周和月模式的日歷,Vue自定義日歷內(nèi)容的顯示,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06

