最近项目中用到两侧数据交换,想到了element里面的穿梭框来写,因为有使用到自定义数据和现实就记录一下吧
1. 要实现的效果
data:image/s3,"s3://crabby-images/9e52b/9e52bde21a1ce251f3ddaa678aced62c6bedbab2" alt=""
因为上方还有选项,实现当选择时间的时候出餐日期就会显示,没有的话就隐藏出餐日期列,所以需要根据条件判断一下是否显示,所以就用到了<span slot-scope="{ option }"></span>来自定义数据项,我本来想用el-row和el-col来布局里面的,最后发现样式显示第二行总是会出现比第一行更宽,样式调理半天未果,就直接用span啦
2. 基本代码
<el-transfer :titles="[ meanInfoUpdate.name1 ==='指定日期'? title:'菜单名称', meanInfoUpdate.name1 ==='指定日期'? title:'菜单名称']"
v-model="value"
:data="data"
style="margin-left:145px;"
@change='changeValue'>
<span slot-scope="{ option }" >
<span style="float:left" class="elCol">
{{option.label}}
</span>
<span style="float:left" v-if="meanInfoUpdate.name1 === '指定日期'">
{{option.time}}
</span>
</span>
</el-transfer>
tips:要准备的数据data和value可以自己去设置,这里就不展示啦,跟着文档走就行啦
data:image/s3,"s3://crabby-images/87189/87189438284a99d963903b559720bf7be0fcd51c" alt=""
3. 因为用到了自定义数据项,就来说一下,自定义的话需要使用 slot-scope 来实现
data:image/s3,"s3://crabby-images/2bc43/2bc43ffdfeb3562075d709108380a270212a0a9a" alt=""
<span slot-scope="{ option }" type="flex">
<span style="float:left" class="elCol">
{{option.label}}
</span>
<span style="float:left" v-if="meanInfoUpdate.name1 === '指定日期'">
{{option.time}}
</span>
</span>
</el-transfer>
实现效果 出餐时间不显示
data:image/s3,"s3://crabby-images/ede23/ede23eb81bb22f3822dfe897f2415af6a8fd28c2" alt=""
出餐时间显示
data:image/s3,"s3://crabby-images/b3cd4/b3cd4828b1b3dd35103fd8f19be54a3967197e75" alt=""
网友评论