老大提出了一个一个设想,我们编辑记录的时候就不要打开弹框了,直接在表格里编辑吧~~~
(╯‵□′)╯︵┻━┻ 让一个后端java开发工程师来写后台管理页面已经很不容易了,这这这这是人能提出的要求吗!!老娘已经不做前端hin!多!年!了!呀!前端的语法我都记不囫囵了!
但是老大是不可能不是人的,作为一只猫球球只能含泪在老大的殷切嘱咐下奋力的滚动起来。
1. 实现单元格编辑
这个和前端同学们咨询了一下以后还是挺好解决的,因为easytable自带控件可以实现。
资料链接:http://doc.huangsw.com/vue-easytable/app.html#/table/cellEdit
引入easytable的<v-table>标签以后我们只要在配置columns的时候增加一个属性:
isEdit:true,
isResize:true
就大功告成了,当然修改以后还要使用方法把修改过的数据保存到数据库里:
<v-table
is-horizontal-resize
style="width:100%"
:columns="columns"
:table-data="tableData"
row-hover-color="#eee"
row-click-color="#edf7ff"
:cell-edit-done="cellEditDone"
></v-table>
然后在v-table的标签里设置':cell-edit-done="cellEditDone"'这个属性就可以在单元格编辑的时候出发方法,cellEditDone方法和其他方法一起定义在method里:
methods:{
// 单元格编辑回调
cellEditDone(newValue,oldValue,rowIndex,rowData,field){
this.tableData[rowIndex][field] = newValue;
// 接下来处理你的业务逻辑,数据持久化等...
}
}
一切遵照文档里的样例来,还可以自己动手操作一把。
2. 单元格里嵌套组件
主要是我们对某一个字段是有限制的,数据库里存的就是1和0,在前台展示就是和否,如果这里也使用单元格编辑的话,那么在操作的时候无法控制操作人员到底输了一些什么进去,我又不是很想用校验来控制。所以我就和新人小学弟说,我们能不能把下拉列表或者单选做到表格里,默认值就是数据库里取出的值,只要用户操作了就更新一把。
小学弟研究了一个下午告诉我不行。
但是作为一只技术程序媛!我这样是没法和老大交代的!毕竟老大最常说的一句话就是”没有什么是技术实现不了的“,我要是这么和他说只怕明天我就成了一只猫饼。
不能姓这个邪啊,于是我亲自操刀上阵,终于找到了解决方法。
资料:http://doc.huangsw.com/vue-easytable/app.html#/table/customColumns
1> 其实在一开始我就想过直接把原始的按钮或者是option组合到column的返回值里,但是发现因为我们在外面包了easytable的框架,所以用原始的代码掉不到我们写在vue框架里的方法。->无奈这条放弃。
2> 既然原始的js代码掉不到,我用iview的代码来可不可以 ->当然是不可以的,所以洗洗碎吧。
3> 可不可以在column里直接return写好的外部组件。->easytable连这个都不支持。
4> easytable有没有自带的方法可以嵌入组件。->有,果然我已经不是一个合格的前端开发了,这点居然弄了半天才想到。
既然找到了嵌入的方法,我第一个想到的是嵌入外部组件,但是到现在也没有成功,如果有谁成功了可以通知我学习一下。
但是嵌入在这个页面定义的自定义组件,还是ok没有问题的。
做法就是在column里定义componentName,通过它传递一个组件,然后在这个组件里写option代码,在这里可以使用@on-change来触发方法。我的组件是这样写的:
// 自定义列组件
Vue.component('test',{
template:`<div><Select v-model="rowData.quoteCss" @on-change="update(1,2)">
<Option v-for="item in booleanList" :value="item.id" :key="item.id">{{ item.name }}</Option>
</Select></div>`,
data:function(){
return {booleanList:[
{
id:1,
name:"是"
},
{
id:0,
name:"否"
}
]}},
props:{
rowData:{
type:Object
},
field:{
type:String
},
index:{
type:Number
}
},
methods:{
update(i, j) {
console.log(i*j);
}
}
})
让我比较开心的是我们可以通过prop获取到rowData,还可以通过data定义一些自己的变量。使用结果完全ok,调用方法也可以调通。其他更多的内容可以参考资料网站。
做完以后发现也还好,但是真的好久不做前端了。