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

vue-列表下詳情的展開(kāi)與折疊案例

 更新時(shí)間:2020年07月28日 15:29:24   作者:佛佛ง  
這篇文章主要介紹了vue-列表下詳情的展開(kāi)與折疊案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

如下所示:

功能描述

1、默認(rèn)折疊,點(diǎn)擊時(shí)展示全部數(shù)據(jù)

2、點(diǎn)擊A項(xiàng),A展開(kāi),之后有兩種情況:①再次點(diǎn)擊A,A折疊;②點(diǎn)擊其他項(xiàng),如B,這時(shí)B展開(kāi),A折疊

解決方式

1、給展開(kāi)折疊圖標(biāo)添加一個(gè)樣式,顯示成動(dòng)畫(huà)效果

<div class="arrow" :class="{'open':showDetail === index}"></div>
.arrow{
 position absolute
 width: 0.6rem;
 height: 0.3rem;
 top 2.0rem
 right 0.8rem
 background url(../../../assets/images/icon_up.png) no-repeat
 background-size: 100% 100%
 transition: transform 0.3s
 -webkit-transition: transform 0.3s
 &.open{
 transform : rotate(-180deg)
 }
}

2、詳情樣式

<transition-group class="expert-detail" tag="div" mode="">
 <div v-for="i in 1" :key="i" class="detail" :ref="`stateopen${index}`" v-show="showDetail===index">
...
 </div>
</transition-group>

3、方法詳情

// 展開(kāi)與折疊
// 分析:
// 1,showDetail默認(rèn)為-1,第一次任意點(diǎn)擊B,當(dāng)前B對(duì)象展開(kāi),showDetail=index=n,此時(shí)有兩種情況:
// 情況1,再次點(diǎn)擊B,showDetail===index,B關(guān)閉,showDetail=-1
// 情況2,點(diǎn)擊B以外的其他對(duì)象C,先關(guān)閉B,在打開(kāi)當(dāng)前對(duì)象C
foldAndUnfold(index,item){
 if(this.showDetail===index){//兩次點(diǎn)擊的對(duì)象相同,關(guān)閉
 this.showDetail = -1
 }else{//點(diǎn)擊的對(duì)象不同,先關(guān)閉前一對(duì)象,再打開(kāi)當(dāng)前對(duì)象
 this.showDetail = index
 }
}

補(bǔ)充知識(shí): Vue table 點(diǎn)擊按鈕展開(kāi)折疊面板

vue 實(shí)現(xiàn)的 table 折疊展開(kāi)功能,由于工作中用到,這里把相應(yīng)代碼整理下,方便自己日后 Copy

1.Html 部分

由基本的 table 表單與折疊欄部分組成

PS:table 上需要加上 ref,以便方法中能夠獲取到 table 屬性

<!-- 注意:el-table 上加一個(gè) ref="table" -->
 <el-table ref="table" :data="list" border style="width: 100%; margin-top:20px; min-height:700px">
  <el-table-column align="center" label="編號(hào)">
  <template slot-scope="scope">
   <span>{{ id }}</span>
  </template>
  </el-table-column>
 
  <el-table-column align="center" label="姓名">
  <template slot-scope="scope">
   <span>{{ name }}</span>
  </template>
  </el-table-column>
 
  <el-table-column label="操作" width="300" align="center" prop="operation">
  <template slot-scope="scope">
   <el-button plain @click="toogleExpand(scope.row)">詳情</el-button>
  </template>
  </el-table-column>
 
  <!-- 展開(kāi)部分 -->
  <el-table-column type="expand" width="1">
  <template slot-scope="props">
   <el-form label-position="left" inline class="demo-table-expand">
   <!-- 參數(shù)列表 -->
   <el-form-item label="1111" label-width="100%">
    aaa
   </el-form-item>
   </el-form>
 
  </template>
  </el-table-column>
 </el-table>

2. vue 的 JS 部分

 <script>
 export default {
  data() {
  return {
   list: [{
   id: '1',
   name: '王小1',
   }, {
   id: '2',
   name: '王小2',
   }, {
   id: '3',
   name: '王小3',
   }, {
   id: '4',
   name: '王小4',
   }]
  }
  },
  
  methods: {
  // 展開(kāi)行效果
  toogleExpand(row) {
   const $table = this.$refs.table
   // 注意,這里的 this.list 是上面 data 中的 list
   // 通過(guò)比對(duì)數(shù)據(jù)與行里的數(shù)據(jù),對(duì)展開(kāi)行進(jìn)行控制,獲取對(duì)應(yīng)值
   this.list.map((item) => {
   if (row.id !== item.id) {
    $table.toggleRowExpansion(item, false)
   }
   })
   $table.toggleRowExpansion(row)
  },
  }
 }
 </script>

3.css 部分

這里除了基本的屬性外,主要我發(fā)現(xiàn)展開(kāi)欄部分會(huì)有空白各自部分,還能拖開(kāi),因此加屬性把多余部分給隱藏掉

下方有注釋

<style>
 /* 展開(kāi)行樣式 */
 .demo-table-expand {
 font-size: 0;
 }
 .demo-table-expand label {
 width: 90px;
 color: #99a9bf;
 }
 .demo-table-expand .el-form-item {
 margin-right: 0;
 margin-bottom: 0;
 width: 100%;
 }
 .el-form-item__content {
 width: 100%;
 }
 /* 隱藏上方表格多余部分 */
 .undefined.el-table__expand-column {
 display: none;
 }
 /* 隱藏上方表格多余部分 */
 .el-table_1_column_8 .el-table--border td, .el-table--border th, .el-table__body-wrapper .el-table--border.is-scrolling-left~.el-table__fixed {
 border-right: 0px solid #ebeef5
 }
</style>

4.效果圖

這個(gè)效果圖是我后面補(bǔ)的,但是功能是以上面來(lái)做的

以上這篇vue-列表下詳情的展開(kāi)與折疊案例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 如何解決Element-ui的el-table固定列后出現(xiàn)的表格錯(cuò)位問(wèn)題

    如何解決Element-ui的el-table固定列后出現(xiàn)的表格錯(cuò)位問(wèn)題

    這篇文章主要介紹了如何解決Element-ui的el-table固定列后出現(xiàn)的表格錯(cuò)位問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • vue-cli4如何打包靜態(tài)資源到指定目錄

    vue-cli4如何打包靜態(tài)資源到指定目錄

    這篇文章主要介紹了vue-cli4打包靜態(tài)資源到指定目錄方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • el-date-picker時(shí)間清空值為null處理方案

    el-date-picker時(shí)間清空值為null處理方案

    本文介紹關(guān)于Vue.js項(xiàng)目中時(shí)間選擇器組件的問(wèn)題,當(dāng)選擇后清空導(dǎo)致值變?yōu)閚ull,進(jìn)而引發(fā)后臺(tái)接口報(bào)錯(cuò),通過(guò)監(jiān)聽(tīng)`overallForm.time`的值并設(shè)置為空數(shù)組,成功解決此問(wèn)題,確保了數(shù)據(jù)正確性,同時(shí),建議避免直接監(jiān)聽(tīng)整個(gè)對(duì)象以優(yōu)化性能,感興趣的朋友一起看看吧
    2024-08-08
  • el-descriptions引入代碼中l(wèi)abel不生效問(wèn)題及解決

    el-descriptions引入代碼中l(wèi)abel不生效問(wèn)題及解決

    這篇文章主要介紹了el-descriptions引入代碼中l(wèi)abel不生效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • vue3-vite安裝后main.ts文件和tsconfig.app.json文件報(bào)錯(cuò)解決辦法

    vue3-vite安裝后main.ts文件和tsconfig.app.json文件報(bào)錯(cuò)解決辦法

    Vue.js是一個(gè)流行的JavaScript框架,它可以幫助開(kāi)發(fā)者構(gòu)建交互式Web應(yīng)用程序,這篇文章主要給大家介紹了關(guān)于vue3-vite安裝后main.ts文件和tsconfig.app.json文件報(bào)錯(cuò)解決辦法,需要的朋友可以參考下
    2023-12-12
  • vue2如何實(shí)現(xiàn)vue3的teleport

    vue2如何實(shí)現(xiàn)vue3的teleport

    這篇文章主要介紹了vue2如何實(shí)現(xiàn)vue3的teleport,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 一篇文章,教你學(xué)會(huì)Vue CLI 插件開(kāi)發(fā)

    一篇文章,教你學(xué)會(huì)Vue CLI 插件開(kāi)發(fā)

    這篇文章主要介紹了Vue CLI插件開(kāi)發(fā),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Vue跳轉(zhuǎn)頁(yè)面的幾種常用方法總結(jié)

    Vue跳轉(zhuǎn)頁(yè)面的幾種常用方法總結(jié)

    在Vue.js中,頁(yè)面跳轉(zhuǎn)是構(gòu)建單頁(yè)面應(yīng)用(SPA)的基本操作之一,本文將介紹Vue中實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)的幾種方法,并通過(guò)實(shí)例代碼幫助理解每種方法的用法,需要的朋友可以參考下
    2024-09-09
  • vue部署后靜態(tài)文件加載404的解決

    vue部署后靜態(tài)文件加載404的解決

    這篇文章主要介紹了vue部署后靜態(tài)文件加載404的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue登錄攔截 登錄后繼續(xù)跳轉(zhuǎn)指定頁(yè)面的操作

    Vue登錄攔截 登錄后繼續(xù)跳轉(zhuǎn)指定頁(yè)面的操作

    這篇文章主要介紹了Vue登錄攔截 登錄后繼續(xù)跳轉(zhuǎn)指定頁(yè)面的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08

最新評(píng)論