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

vue?el-table實現(xiàn)動態(tài)添加行和列具體代碼

 更新時間:2023年09月15日 11:39:36   作者:別拿曾經看以后~  
最近遇到一個動態(tài)增加行和列的需求,所以這里給大家總結下,這篇文章主要給大家介紹了關于vue?el-table實現(xiàn)動態(tài)添加行和列的相關資料,需要的朋友可以參考下

實現(xiàn)思路:

最近遇到一個動態(tài)增加行和列的需求,本來拿到需求的時候想用el-table中自帶的方法去實現(xiàn)的,但是經過嘗試發(fā)現(xiàn)不能滿足想要實現(xiàn)的需求。沒辦法只能在el-table的基礎上自己寫原生。

大概思路如下:

1.首先把table中需要動態(tài)增加的行和列分開,分別定義一個數(shù)組dataList存放新增行數(shù)據,定義數(shù)組columnList存放新增列數(shù)據。

2.其次在指定列的數(shù)據前面加新增按鈕,點擊新增按鈕的時候請求接口拿到數(shù)據。

3.然后把拿到的數(shù)據處理,把表格內容的數(shù)據push到dataList中,把表頭內容數(shù)據push到columnList中。注意如果接口沒有返回表頭數(shù)據,則需要自己根據具體需求創(chuàng)造對應列的key-value存入columnList中。

(1)行可以直接添加在現(xiàn)有行后面展示,也可以在指定行的后面新增行。比如:在第一行后面新增行,則使用splice添加。splice(指定行,0,添加的新行數(shù)據)

(2)點擊哪行則在哪行后面添加新行。思路:獲取到當前點擊行的索引,使用splice添加。splice(指定行,0,添加的新行數(shù)據)

4.最后把dataList給el-table的:data="dataList"使用,columnList給使用

5.以上是新增行和列的思路。如果想刪除行和列的話,則需要通過splice或slice操作dataList和columnList即可。刪除指定的索引位置。

大致代碼如下:

<el-table :data="dataList">
	<el-table-column label="姓名" prop="name"></el-table-column>
	<!--動態(tài)列-->
	<el-table-column v-for="(it, index) in columnList" :key="index" :label="it.label">
		<!--動態(tài)行-->
		<template slot-scope="scope">
			<i class="el-icon-circle-plus-outline" @click="handleAddRow(scope.row, scope.$index)" />
			<span>{{scope.row.value}}</span>
			// 根據項目需求進行其他邏輯處理
		</template>
	</el-table-column>
</el-table>
export default {
	data() {
		return {
			dataList: [], // 表格數(shù)據
			columnList: [], //表頭數(shù)據
		}
	},
	methods: {
		// 動態(tài)增加行
		async handleAddRow(row, index) {
			const data = await this.接口()
			data.forEach(d => {
				// 列添加
				this.columnList.push({ label: '年齡' })
				// 行添加
			    this.dataList.splice(index, 0, d)
			})
		}
	}
}

結語:

以上是el-table動態(tài)添加行和列的大概思路,大家可以作為參考,再結合具體需求細化?。?!

補充:vue實現(xiàn)el-table表頭自定義

Vue.js 是一個流行的JavaScript框架,它的數(shù)據綁定和組件化特性使得開發(fā)動態(tài)Web應用變得更加容易。其中,強大的UI組件庫(如Element,iView等)能夠極大地提高Web應用開發(fā)效率。而el-table是一種用于展示表格數(shù)據的組件,它擁有可排序、過濾、分頁等多種功能。本文主要介紹如何使用Vue.js實現(xiàn)el-table表頭自定義。

在Vue.js中使用el-table組件時,表頭(thead)用于顯示列名和控制排序、過濾等操作。默認情況下,el-table組件根據數(shù)據源中的列名自動生成表頭。若需自定義表頭,可通過以下方式實現(xiàn):

  • 使用el-table-column組件

在el-table中使用el-table-column組件可以實現(xiàn)自定義表頭。具體操作如下:

<el-table :data="tableData">
  <el-table-column prop="date" label="日期"></el-table-column>
  <el-table-column prop="name" label="姓名"></el-table-column>
  <el-table-column prop="address" label="地址"></el-table-column>
</el-table>

上述代碼中,我們?yōu)閑l-table添加了三個el-table-column組件,分別對應表格中的三列數(shù)據。同時,我們在每個el-table-column組件上指定了prop和label屬性,其中prop屬性指定了對應的數(shù)據源中的字段名,label屬性指定了表頭標題。

  • 使用Scoped Slots

如果需要實現(xiàn)更加復雜的表頭,可以使用Scoped Slots進行自定義。具體操作如下:

<el-table :data="tableData">
  <template slot="header">
    <el-row>
      <el-col :span="8">日期</el-col>
      <el-col :span="8">姓名</el-col>
      <el-col :span="8">地址</el-col>
    </el-row>
  </template>
  <el-table-column prop="date"></el-table-column>
  <el-table-column prop="name"></el-table-column>
  <el-table-column prop="address"></el-table-column>
</el-table>

上述代碼中,我們使用了el-table的header slot,它可以讓我們自定義表頭,即在表頭中添加任意HTML代碼。在header slot中我們使用了el-row和el-col組件創(chuàng)建了一個表頭行,然后通過span屬性設置每列所占的寬度,最終實現(xiàn)了自定義表頭。

到此這篇關于vue el-table實現(xiàn)動態(tài)添加行和列的文章就介紹到這了,更多相關el-table動態(tài)添加行和列內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue和Bootstrap的整合思路詳解

    Vue和Bootstrap的整合思路詳解

    這篇文章主要介紹了Vue和Bootstrap的整合思路詳解,需要的朋友可以參考下
    2017-06-06
  • vue3.0-monaco組件封裝存檔代碼解析

    vue3.0-monaco組件封裝存檔代碼解析

    這篇文章主要介紹了vue3.0-monaco組件封裝存檔代碼解析,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-03-03
  • Vue-cli-webpack搭建斗魚直播步驟詳解

    Vue-cli-webpack搭建斗魚直播步驟詳解

    斗魚直播是比較火的直播視頻,想必大家都看過吧。這篇文章主要介紹了Vue-cli-webpack搭建斗魚直播步驟詳解,需要的朋友可以參考下
    2017-11-11
  • 簡單方法實現(xiàn)Vue?無限滾動組件示例

    簡單方法實現(xiàn)Vue?無限滾動組件示例

    這篇文章主要為大家介紹了簡單方法實現(xiàn)Vue?無限滾動組件示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • Vue+WebSocket頁面實時刷新長連接的實現(xiàn)

    Vue+WebSocket頁面實時刷新長連接的實現(xiàn)

    最近vue項目要做數(shù)據實時刷新,數(shù)據較大,會出現(xiàn)卡死情況,所以本文主要介紹了頁面實時刷新長連接,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • VUE實現(xiàn)一個Flappy Bird游戲的示例代碼

    VUE實現(xiàn)一個Flappy Bird游戲的示例代碼

    這篇文章主要介紹了VUE實現(xiàn)一個Flappy Bird的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • vue組件開發(fā)之slider組件使用詳解

    vue組件開發(fā)之slider組件使用詳解

    這篇文章主要為大家詳細介紹了vue組件開發(fā)之slider組件的使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 詳解vue-cli 快速搭建單頁應用之遇到的問題及解決辦法

    詳解vue-cli 快速搭建單頁應用之遇到的問題及解決辦法

    這篇文章主要介紹了詳解vue-cli 快速搭建單頁應用之遇到的問題及解決辦法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • Vue.js@2.6.10更新內置錯誤處機制Fundebug同步支持相應錯誤監(jiān)控

    Vue.js@2.6.10更新內置錯誤處機制Fundebug同步支持相應錯誤監(jiān)控

    這篇文章主要介紹了Vue.js@2.6.10更新內置錯誤處機制,F(xiàn)undebug同步支持相應錯誤監(jiān)控 ,需要的朋友可以參考下
    2019-05-05
  • Vue首屏白屏問題的原因和解決方法講解

    Vue首屏白屏問題的原因和解決方法講解

    這篇文章主要介紹了Vue首屏白屏問題的原因和解決方法講解,Vue首屏白屏問題是指在頁面初次加載時,部分或全部內容無法正常顯示,出現(xiàn)空白的情況。其原因可能是因為頁面渲染速度過慢,或者是因為網絡請求等問題導致數(shù)據無法及時加載
    2023-05-05

最新評論