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

vue表格(table)計(jì)算總計(jì)方式

 更新時(shí)間:2022年07月31日 10:02:40   作者:manyuejizhao  
這篇文章主要介紹了vue表格(table)計(jì)算總計(jì)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue 表格計(jì)算總計(jì)

<el-table
? ? ? ? v-loading="loading"
? ? ? ? :summary-method="getSummaries"
? ? ? ? show-summary
? ? ? ? :data="abcList"
? ? ? ? border
? ? ? ? tooltip-effect="darkTable"
? ? ? >

首先需要在table標(biāo)簽中添加

:summary-method="getSummaries" ?// 調(diào)用方法
show-summary ?//標(biāo)簽屬性
methods: {
? getSummaries(param) {
? ? const { columns, data } = param
? ? console.log(columns, data, 'columns,data')
? ? const sums = []
? ? columns.forEach((column, index) => {
? ? ? // 設(shè)置第一列的值為總計(jì)
? ? ? if (index === 0) {
? ? ? ? sums[index] = '總計(jì)'
? ? ? ? return
? ? ? }
? ? ? ? sums[3] = this.form.result
? ? ? ? sums[3] += '元'
? ? })
? ? return sums
? ?}
}

因?yàn)镋lement上計(jì)算總計(jì)的方法是計(jì)算當(dāng)前頁(yè)上金額的總和,稍加修改~

sums[index] = '總計(jì)' ?
// 把下標(biāo)為0的列賦值為總計(jì)
sums[3] = this.form.result ?
// this.form.result為init初始化時(shí)從接口中拿到的總計(jì),賦值到下標(biāo)為3的列上
sums[3] += '元'
// 得到的總計(jì)后加上單位元

vue table表格合計(jì) ( Element )

<template>
	<el-card class="box-card">
		<!-- 只合計(jì)不做其他處理 -->
		<h2>只合計(jì)不做其他處理</h2>
		<el-table :data="tableData6" border show-summary style="width: 100%">
			<el-table-column prop="id" label="ID" width="180" align="center">
			</el-table-column>
			<el-table-column prop="name" label="產(chǎn)品" align="center">
			</el-table-column>
			<el-table-column prop="number" label="數(shù)量" align="center">
			</el-table-column>
			<el-table-column prop="price" label="價(jià)格" align="center">
			</el-table-column>
			<el-table-column prop="profit" label="利潤(rùn)率" align="center">
			</el-table-column>
		</el-table>
 
		<!-- 簡(jiǎn)單求和實(shí)例處理 -->
		<h2 style="margin-top:100px">簡(jiǎn)單求和實(shí)例處理</h2>
		<el-table :data="tableData6" border :summary-method="getSummaries01" show-summary style="width: 100%;">
			<el-table-column prop="id" label="ID" width="180" align="center">
			</el-table-column>
			<el-table-column prop="name" label="產(chǎn)品" align="center">
			</el-table-column>
			<el-table-column prop="number" label="數(shù)量" align="center">
			</el-table-column>
			<el-table-column prop="price" label="價(jià)格" align="center">
			</el-table-column>
			<el-table-column prop="profit" label="利潤(rùn)率" align="center">
			</el-table-column>
		</el-table>
 
		<!-- 指定列求和實(shí)例處理 -->
		<h2 style="margin-top:100px">指定列求和實(shí)例處理</h2>
		<el-table :data="tableData6" border :summary-method="getSummaries02" show-summary style="width: 100%;">
			<el-table-column prop="id" label="ID" width="180" align="center">
			</el-table-column>
			<el-table-column prop="name" label="產(chǎn)品" align="center">
			</el-table-column>
			<el-table-column prop="number" label="數(shù)量" align="center">
			</el-table-column>
			<el-table-column prop="price" label="價(jià)格" align="center">
				<template slot-scope="scope">
					{{$utils.formSum(scope.row.price, 2, '.', ',')}}
				</template>
			</el-table-column>
			<el-table-column prop="profit" label="利潤(rùn)率" align="center">
				<template slot-scope="scope">
					{{Number(scope.row.profit).toFixed(2)}} %
				</template>
			</el-table-column>
		</el-table>
	</el-card>
</template>
 
<script>
	export default {
		data() {
			return {
				tableData6: [{
					id: '12987122',
					name: '襪子',
					number: '234',
					price: '3',
					profit: '10.9'
				}, {
					id: '12987123',
					name: '鞋子',
					number: '165',
					price: '343.8',
					profit: '12.00'
				}, {
					id: '12987124',
					name: '褲子',
					number: '324',
					price: '249.0',
					profit: '9'
				}, {
					id: '12987125',
					name: '腰帶',
					number: '621',
					price: '342.0',
					profit: '17.00'
				}, {
					id: '12987126',
					name: '手鐲',
					number: '539',
					price: '43421',
					profit: '153333'
				}]
			};
		},
		methods: {
			//格式化數(shù)字,格式化金額
			// formSum: function(number, decimals, dec_point, thousands_sep) {
			//   /*   
			//     * 參數(shù)說明:
 
			//     * number:要格式化的數(shù)字
 
			//     * decimals:保留幾位小數(shù)
 
			//     * dec_point:小數(shù)點(diǎn)符號(hào)
 
			//     * thousands_sep:千分位符號(hào)
 
			//     * */
			//   number = (number + '').replace(/[^0-9+-Ee.]/g, '');
			//   var n = !isFinite(+number) ? 0 : +number,
			//     prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),
			//     sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep,
			//     dec = (typeof dec_point === 'undefined') ? '.' : dec_point,
			//     s = '',
			//     toFixedFix = function(n, prec) {
			//       var k = Math.pow(10, prec);
			//       return '' + Math.ceil(n * k) / k;
			//     };
			//   s = (prec ? toFixedFix(n, prec) : '' + Math.round(n)).split('.');
			//   var re = /(-?\d+)(\d{3})/;
			//   while (re.test(s[0])) {
			//     s[0] = s[0].replace(re, "$1" + sep + "$2");
			//   }
			//   if ((s[1] || '').length < prec) {
			//     s[1] = s[1] || '';
			//     s[1] += new Array(prec - s[1].length + 1).join('0');
			//   }
			//   return s.join(dec);
			// }
			/**
			 * 將show-summary設(shè)置為true就會(huì)在表格尾部展示合計(jì)行。
			 * 默認(rèn)情況下,對(duì)于合計(jì)行,第一列不進(jìn)行數(shù)據(jù)求合操作,
			 * 而是顯示「合計(jì)」二字(可通過sum-text配置),
			 * 其余列會(huì)將本列所有數(shù)值進(jìn)行求合操作,并顯示出來。
			 * 當(dāng)然,你也可以定義自己的合計(jì)邏輯。
			 * 使用summary-method并傳入一個(gè)方法,返回一個(gè)數(shù)組,
			 * 這個(gè)數(shù)組中的各項(xiàng)就會(huì)顯示在合計(jì)行的各列中,具體可以參考本例中的第二個(gè)表格。
			 */
 
			//簡(jiǎn)單求和實(shí)例處理
			getSummaries01(param) {
				const {
					columns,
					data
				} = param;
				const sums = [];
				columns.forEach((column, index) => {
					if (index === 0) {
						sums[index] = '總價(jià)';
						return;
					}
					const values = data.map(item => Number(item[column.property]));
					if (!values.every(value => isNaN(value))) {
						sums[index] = values.reduce((prev, curr) => {
							const value = Number(curr);
							if (!isNaN(value)) {
								return prev + curr;
							} else {
								return prev;
							}
						}, 0);
						sums[index] += ' 元';
					} else {
						sums[index] = 'N/A';
					}
				});
				return sums;
			},
 
 
 
			//指定列求和實(shí)例處理
			getSummaries02(param) {
				const {
					columns,
					data
				} = param;
				const sums = [];
				columns.forEach((column, index) => {
					if (index === 0) {
						sums[index] = '總價(jià)';
					} else if (index === 3) { //對(duì)價(jià)格做處理:保留兩位小數(shù)
						const values = data.map(item => Number(item[column.property]));
						if (!values.every(value => isNaN(value))) {
							sums[index] = values.reduce((prev, curr) => {
								const value = Number(curr);
								if (!isNaN(value)) {
									return prev + curr;
								} else {
									return prev;
								}
							}, 0);
							sums[index] = this.$utils.formSum(sums[index], 2, '.', ',');
						} else {
							sums[index] = '/';
						}
					} else if (index === 4) { //對(duì)利潤(rùn)率做處理:保留兩位小數(shù)
						const values = data.map(item => Number(item[column.property]));
						if (!values.every(value => isNaN(value))) {
							sums[index] = values.reduce((prev, curr) => {
								const value = Number(curr);
								if (!isNaN(value)) {
									return prev + curr;
								} else {
									return prev;
								}
							}, 0);
							sums[index] = sums[index].toFixed(2);
							sums[index] += ' %';
						} else {
							sums[index] = '/';
						}
					} else {
						const values = data.map(item => Number(item[column.property]));
						if (!values.every(value => isNaN(value))) {
							sums[index] = values.reduce((prev, curr) => {
								const value = Number(curr);
								if (!isNaN(value)) {
									return prev + curr;
								} else {
									return prev;
								}
							}, 0);
						} else {
							sums[index] = '/';
						}
					}
				});
				return sums;
			}
		}
	};
</script>

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • ElementUI中el-dropdown-item點(diǎn)擊事件無效問題

    ElementUI中el-dropdown-item點(diǎn)擊事件無效問題

    這篇文章主要介紹了ElementUI中el-dropdown-item點(diǎn)擊事件無效問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vant組件中 dialog的確認(rèn)按鈕的回調(diào)事件操作

    vant組件中 dialog的確認(rèn)按鈕的回調(diào)事件操作

    這篇文章主要介紹了vant組件中 dialog的確認(rèn)按鈕的回調(diào)事件操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 基于Vue實(shí)現(xiàn)本地消息隊(duì)列MQ的示例詳解

    基于Vue實(shí)現(xiàn)本地消息隊(duì)列MQ的示例詳解

    這篇文章為大家詳細(xì)主要介紹了如何基于Vue實(shí)現(xiàn)本地消息隊(duì)列MQ, 讓消息延遲消費(fèi)或者做緩存,文中的示例代碼講解詳細(xì),需要的可以參考一下
    2024-02-02
  • 詳解vue大文件視頻切片上傳的處理方法

    詳解vue大文件視頻切片上傳的處理方法

    前端上傳大文件、視頻的時(shí)候會(huì)出現(xiàn)超時(shí)、過大、很慢等情況,為了解決這一問題,跟后端配合做了一個(gè)切片的功能,接下來就詳細(xì)的給大家介紹一下vue大文件視頻切片上傳的處理方法,需要的朋友可以參考下
    2023-08-08
  • 深入了解Vue使用vue-qr生成二維碼的方法

    深入了解Vue使用vue-qr生成二維碼的方法

    這篇文章主要為大家介紹了Vue使用vue-qr生成二維碼的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Vue2遞歸組件實(shí)現(xiàn)樹形菜單

    Vue2遞歸組件實(shí)現(xiàn)樹形菜單

    這篇文章主要為大家詳細(xì)介紹了Vue2遞歸組件實(shí)現(xiàn)樹形菜單的相關(guān)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 深入解析Vue的自定義指令

    深入解析Vue的自定義指令

    這篇文章主要介紹了深入解析Vue的自定義指令,自定義指令主要是為了重用涉及普通元素的底層 DOM 訪問的邏輯,一個(gè)自定義指令由一個(gè)包含類似組件生命周期鉤子的對(duì)象來定義,需要的朋友可以參考下
    2023-05-05
  • vue 優(yōu)化CDN加速的方法示例

    vue 優(yōu)化CDN加速的方法示例

    這篇文章主要介紹了vue 優(yōu)化CDN加速的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • Vue.js實(shí)現(xiàn)表格動(dòng)態(tài)增加刪除的方法(附源碼下載)

    Vue.js實(shí)現(xiàn)表格動(dòng)態(tài)增加刪除的方法(附源碼下載)

    Vue.js通過簡(jiǎn)潔的API提供高效的數(shù)據(jù)綁定和靈活的組件系統(tǒng)。在前端紛繁復(fù)雜的生態(tài)中,Vue.js有幸受到一定程度的關(guān)注,下面這篇文章主要給介紹了Vue.js實(shí)現(xiàn)表格動(dòng)態(tài)增加刪除的方法實(shí)例,文末提供了源碼下載,需要的朋友可以參考借鑒。
    2017-01-01
  • vue如何動(dòng)態(tài)實(shí)時(shí)的顯示時(shí)間淺析

    vue如何動(dòng)態(tài)實(shí)時(shí)的顯示時(shí)間淺析

    這篇文章主要給大家介紹了關(guān)于vue如何動(dòng)態(tài)實(shí)時(shí)的顯示時(shí)間,以及vue時(shí)間戳 獲取本地時(shí)間實(shí)時(shí)更新的相關(guān)資料,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05

最新評(píng)論