my-crud ist eine auf D2-Crud basierende Vue-Tabellenkomponente. Sie enthält ein einfaches Hinzufügungs-, Lösch- und Änderungsformular und fügt gegenüber der Originalversion einige Funktionen hinzu.
Verwenden Sie npm
npm i element-ui my-element-crud -S
Schreiben Sie den folgenden Inhalt in main.js
:
import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import D2Crud from 'my-element-crud'
Vue . use ( ElementUI )
Vue . use ( D2Crud )
new Vue ( {
el : '#app' ,
render : h => h ( App )
} )
Anschließend können Sie D2-Crud
in Ihrem Projekt verwenden.
Externe: D2Crud
https://cdn.d2.pub/packages/@d2-projects/[email protected]/d2-crud.js
custom: [
{
text : '更多' ,
type : 'text' ,
// size: 'small',
sort : 8 ,
emit : 'custom-edit' ,
show : ( index , row ) => true ,
more : [
{
text : '!!!!!' ,
emit : 'custom-pop' ,
show : ( index , row ) => true
}
]
}
]
mycom2 : {
title : "自带选择框" ,
value : "" ,
_sort : 4 ,
component : {
name : "el-select" ,
options : [
{ label : "测试1" , value : 1 } ,
{ label : "测试2" , value : 2 } ,
] ,
// 事件绑定
'@change' : ( e ) => {
console . log ( this . rowHandle ) ;
} ,
// 属性绑定
':size' : 'mini'
} ,
} ,
Lösen Sie das Problem, dass das Formulardatenänderungsereignis des integrierten Auswahlfelds nicht korrekt an die übergeordnete Komponente übergeben werden kann
Schaltfläche „Benutzerdefinierte Ansicht hinzufügen“.
Anzeigefunktion hinzufügen, Elemente sind beim Anzeigen standardmäßig deaktiviert
Die benutzerdefinierte Komponente „disabled“ muss „disabled: Boolean“ in den Requisiten hinzufügen. Schreiben Sie das Komponentenattribut: :disabled="disabled".
verwenden:
< d2-crud v-bind : look-template = "addTemplate" > </ d2-crud >
rowHandle: {
look : {
text : "查看" ,
emit : "lookHandle"
} ,
}
Fügen Sie eine benutzerdefinierte Sortierfunktion für Schaltflächen hinzu
verwenden:
rowHandle: {
minWidth : "180px" ,
look : {
text : "查看" ,
emit : "lookHandle" ,
sort : 3
} ,
customs : [ {
text : '打卡记录' ,
emit : 'showRecord' ,
sort : 2
} ] ,
edit : {
text : "编辑" ,
emit : "editHandle" ,
type : "warning " ,
sort : 1
} ,
}
rowHandle: {
lookNoEle : {
text : "查看" ,
emit : "lookHandle"
} ,
}
mycom : {
title : "选择框" ,
value : "" ,
component : {
name : testCom ,
formatter ( val ) {
return val === 1 ? "测试1" : "测试2" ;
} ,
props : {
options : [
{ label : "测试1" , value : 1 } ,
{ label : "测试2" , value : 2 }
]
}
}
} ,
roleName : {
title : "角色名" ,
value : "" ,
class : "my_label" ,
component : {
placeholder : " 仅可输入英文大小写、数字"
}
} ,
- Fügen Sie eine dynamische Anzeige und ein ausgeblendetes Formular hinzu
roleName : {
title : "角色名" ,
value : "" ,
class : "my_label" ,
component : {
show : this . show === 1
placeholder : " 仅可输入英文大小写、数字"
}
} ,
Legen Sie die Breite des Formulardialogs fest: add-width="400px" :edit-width="400px"
=======
übergeordnete Komponente
< d2-crud
@componentEvent:coma =" handle " >
</ d2-crud >
computed : {
addTemplate ( ) {
return {
coma : {
title : "自定义选择框a" ,
value : "" ,
component : {
name : coma ,
} ,
} ,
comb : {
title : "自定义选择框b" ,
value : "" ,
component : {
name : comb ,
} ,
} ,
}
} ,
method : {
handle ( data ) {
this . $refs . d2Crud . getRef ( "comb" ) . handleComponentEvent ( data ) ;
} }
Komponente A
<template>
<div>
<el-button @click="up">up123</el-button>
</div>
</template>
up() {
this.$emit("componentEvent", 123);
}
Komponente B
methods: {
handleComponentEvent ( data ) {
this . data = data
}
}