本篇文章為大家展示了vue el-table實(shí)現(xiàn)行內(nèi)編輯功能,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

(1) 自定義 el-table 的表頭(即添加 “新增” 按鈕):
<el-table :data="propTableData.col.filter(data => handleAdd || data.name.toLowerCase().includes(handleAdd.toLowerCase()))" highlight-current-row border> </el-table>
<template slot="header"
slot-scope="scope">
<el-button v-model="handleAdd"
size="mini"
type="success"
round
plain
@click="handleAdd(scope.$index, scope.row)">{{ $t('common.add') }}</el-button>
</template>表頭自定義了一個(gè)“添加”按鈕,點(diǎn)擊 el-table 動(dòng)態(tài)添加一行。
(2) el-table 動(dòng)態(tài)添加一行:
let row = {
code: '',
maxValue: '',
minValue: '',
name: '',
valueType: 'String',
id: '',
typeId: '',
warning: false,
isSet: true
}
this.propTableData.col.push(row)vue 數(shù)據(jù)變化驅(qū)動(dòng) dom 進(jìn)行更新,給 table 綁定的數(shù)據(jù) propTableData.col 添加一個(gè)元素,則表格會(huì)添加一行。
propTableData.sel 保存當(dāng)前行數(shù)據(jù):
this.propTableData.sel = row
(3) el-table 動(dòng)態(tài)刪除一行:
子組件中觸發(fā)父組件的 delete 事件:
this.$emit('delete', row.id)(4)當(dāng)前行狀態(tài)判斷,即是否處于編輯狀態(tài),控制表格每一行的按鈕元素的移除與插入:
<template slot-scope="scope">
<el-button size="mini"
type="primary"
round
plain
v-if="!scope.row.isSet"
@click="valChange(scope.row,scope.$index,true)">{{ $t('common.edit') }}</el-button>
<el-button size="mini"
type="primary"
round
plain
v-else
@click="valChange(scope.row,scope.$index,true)">{{ $t('common.save') }}</el-button>
<el-button size="mini"
type="danger"
round
plain
v-if="!scope.row.isSet"
@click="handleDelete(scope.$index, scope.row)">{{ $t('common.delete') }}</el-button>
<el-button size="mini"
type="danger"
round
plain
v-else
@click="valChange(scope.row,scope.$index,false)">{{ $t('common.cancel') }}</el-button>
</template>上面代碼中,通過 v-if=“scope.row.isSet” 來判斷當(dāng)前行是否處于編輯狀態(tài)。
如果當(dāng)前行處于編輯狀態(tài),則按鈕為“保存”和“取消”,此時(shí)可對(duì)當(dāng)前行進(jìn)行保存和取消操作,且不能新增,除非先保存當(dāng)前行;
如果當(dāng)前行處于非編輯狀態(tài),則按鈕為“編輯”和“刪除”狀態(tài),此時(shí)可對(duì)當(dāng)前行進(jìn)行編輯和刪除操作。
這樣,就可以實(shí)現(xiàn) el-table 行內(nèi)編輯的需求。

完整版代碼如下:
<template>
<el-dialog class="uiot-dialog"
width="900px"
:visible.sync="isShow"
:before-close="beforeClose"
:close-on-click-modal="false"
:title="$t('basicData.device.propDlg.dlgTitle')"
@open="open">
<el-table :data="propTableData.col.filter(data => handleAdd || data.name.toLowerCase().includes(handleAdd.toLowerCase()))"
highlight-current-row
border>
<el-table-column label="No."
type="index"
align="center"
width="50"></el-table-column>
<el-table-column :label="$t('basicData.device.propDlg.code')">
<template slot-scope="scope">
<span v-if="scope.row.isSet">
<el-input size="mini"
v-model="scope.row.code"></el-input>
</span>
<span v-else>{{ scope.row.code }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('basicData.device.propDlg.name')">
<template slot-scope="scope">
<span v-if="scope.row.isSet">
<el-input size="mini"
v-model="scope.row.name"></el-input>
</span>
<span v-else>{{ scope.row.name }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('basicData.device.propDlg.minValue')">
<template slot-scope="scope">
<span v-if="scope.row.isSet">
<el-input size="mini"
v-model="scope.row.minValue"></el-input>
</span>
<span v-else>{{ scope.row.minValue }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('basicData.device.propDlg.maxValue')">
<template slot-scope="scope">
<span v-if="scope.row.isSet">
<el-input size="mini"
v-model="scope.row.maxValue"></el-input>
</span>
<span v-else>{{ scope.row.maxValue }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('basicData.device.propDlg.valueType')">
<template slot-scope="scope">
<span v-if="scope.row.isSet">
<el-select size="mini"
v-model="scope.row.valueType"
:placeholder="$t('common.pleSelect')">
<el-option v-for="item in valTypeOptions"
:key="item.value"
:label="item.label"
:value="item.value"></el-option>
</el-select>
</span>
<span v-else>{{ scope.row.valueType }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('basicData.device.propDlg.warning')">
<template slot-scope="scope">
<span v-if="scope.row.isSet">
<el-select v-model="scope.row.warning"
size="mini">
<el-option v-for="item in warnOptions"
:key="item.value"
:label="item.label"
:value="item.value"></el-option>
</el-select>
</span>
<span v-else>{{ scope.row.warning===true?'是':'否' }}</span>
</template>
</el-table-column>
<el-table-column align="center"
width="170px">
<template slot="header"
slot-scope="scope">
<el-button v-model="handleAdd"
size="mini"
type="success"
round
plain
@click="handleAdd(scope.$index, scope.row)">{{ $t('common.add') }}</el-button>
</template>
<template slot-scope="scope">
<el-button size="mini"
type="primary"
round
plain
v-if="!scope.row.isSet"
@click="valChange(scope.row,scope.$index,true)">{{ $t('common.edit') }}</el-button>
<el-button size="mini"
type="primary"
round
plain
v-else
@click="valChange(scope.row,scope.$index,true)">{{ $t('common.save') }}</el-button>
<el-button size="mini"
type="danger"
round
plain
v-if="!scope.row.isSet"
@click="handleDelete(scope.$index, scope.row)">{{ $t('common.delete') }}</el-button>
<el-button size="mini"
type="danger"
round
plain
v-else
@click="valChange(scope.row,scope.$index,false)">{{ $t('common.cancel') }}</el-button>
</template>
</el-table-column>
</el-table>
</el-dialog>
</template>
<script>
import { open } from 'fs'
import '@/styles/uiot.scss'
const defaultProp = {
code: '',
maxValue: '',
minValue: '',
name: '',
valueType: 'String',
id: '',
typeId: '',
warning: false
}
export default {
props: {
isShow: Boolean,
oneRow: {
type: Array,
default: function() {
return defaultProp
}
}
},
data() {
return {
propTableData: {
sel: null, // 選中行
col: []
},
warnOptions: [
{
value: true,
label: '是'
},
{
value: false,
label: '否'
}
],
valTypeOptions: [
{
value: 'String',
label: 'String'
},
{
value: 'Int',
label: 'Int'
},
{
value: 'Double',
label: 'Double'
},
{
value: 'Boolean',
label: 'Boolean'
},
{
value: 'Date',
label: 'Date'
}
]
}
},
created() {},
methods: {
open() {
this.propTableData.col = this.oneRow
this.propTableData.col.map(i => {
i.isSet = false
})
console.log('open', this.propTableData.col)
},
// 添加
handleAdd() {
for (let i of this.propTableData.col) {
if (i.isSet) {
return this.Message(
this.$t('basicData.device.propDlg.pleSave'),
'warning'
)
}
}
let row = {
code: '',
maxValue: '',
minValue: '',
name: '',
valueType: 'String',
id: '',
typeId: '',
warning: false,
isSet: true
}
this.propTableData.col.push(row)
this.propTableData.sel = row
},
//修改
valChange(row, index, qx) {
console.log('edit', this.propTableData)
//點(diǎn)擊修改,判斷是否已經(jīng)保存所有操作
for (let i of this.propTableData.col) {
console.log('i.isSet', i.isSet, i.id, row.id)
if (i.isSet && i.id != row.id) {
this.Message(this.$t('basicData.device.propDlg.pleSave'), 'warning')
return false
}
}
//是否是取消操作
if (!qx) {
console.log('qx', this.propTableData.sel.id)
if (!this.propTableData.sel.id) {
this.propTableData.col.splice(index, 1)
}
return (row.isSet = !row.isSet)
}
//提交數(shù)據(jù)
if (row.isSet) {
console.log('this.propTableData.sel', this.propTableData.sel)
const v = this.propTableData.sel
// 必填項(xiàng)判斷
if (v.code == '' || v.name == '') {
this.Message(this.$t('common.pleEnter'), 'warning')
} else {
this.$emit('confirm', this.propTableData.sel)
row.isSet = false
}
} else {
this.propTableData.sel = row
row.isSet = true
}
},
// 刪除
handleDelete(index, row) {
this.$emit('delete', row.id)
},
beforeClose() {
this.$emit('cancel')
},
Message(msg, type) {
this.$message({ type: type ? type : 'info', message: msg })
}
}
}
</script>
<style lang="scss">
</style>上述內(nèi)容就是vue el-table實(shí)現(xiàn)行內(nèi)編輯功能,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
標(biāo)題名稱:vueel-table實(shí)現(xiàn)行內(nèi)編輯功能-創(chuàng)新互聯(lián)
標(biāo)題鏈接:http://chinadenli.net/article16/hpggg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、域名注冊(cè)、手機(jī)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)公司、網(wǎng)站營銷、標(biāo)簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容