本文主要是介绍elementUI浅谈Tag组件的before-leave属性实现条件跳转页面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在一个el-tabs
里,每一个<el-tab-pane>
都对应一个name属性,就是这个<el-tab-pane>
的编号,比如我们就用0-4来表示这5个<el-tab-pane>
,点击一个<el-tab-pane>
,el-tabs
绑定的v-model="activeIndex"
的值就会自动变成对应被点击的<el-tab-pane>
的name
属性值
el-tabs
里的:before-leave="beforeTabLeave
属性接收一个函数
这个函数接收两个参数,前一个是点击的活跃的<el-tab-pane>
标签的name
属性的值,第二个参数是之前活跃的<el-tab-pane>
标签name
属性的值,效果如下:
如何让<el-tab-pane>
不能随着点击切换呢?
我们只要在:before-leave
的回调函数里面return false或者返回一个promise对象并且reject就可以阻止页面点击跳转:
我们现在要做一个功能,就是不选择商品分类(必须是第三级分类)就不允许点击跳转到其他的<el-tab-pane>
,可以这样做:
现在不选择分类,或者只选择了二级分类,都不允许跳转到别的<el-tab-pane>
并且弹出提醒对话框
效果:
<el-form :model="addForm" :rules="addFormRules" ref="addFormRef" label-width="100px" label-position="top"><el-tabs v-model="activeIndex" :tab-position="'left'" :before-leave="beforeTabLeave"><el-tab-pane label="基本信息" name="0"><el-form-item label="商品名称" prop="goods_name"><el-input v-model="addForm.goods_name"></el-input></el-form-item><el-form-item label="商品价格" prop="goods_price"><el-input v-model="addForm.goods_price" type="number"></el-input></el-form-item><el-form-item label="商品重量" prop="goods_weight"><el-input v-model="addForm.goods_weight" type="number"></el-input></el-form-item><el-form-item label="商品数量" prop="goods_number"><el-input v-model="addForm.goods_number" type="number"></el-input></el-form-item><el-form-item label="商品分类" prop="goods_cat"><el-cascaderexpand-trigger="hover":options="cateList":props="cateProps"v-model="addForm.selectedCateKeys"@change="handleChange"></el-cascader></el-form-item></el-tab-pane><el-tab-pane label="商品参数" name="1">商品参数</el-tab-pane><el-tab-pane label="商品属性" name="2">商品属性</el-tab-pane><el-tab-pane label="商品图片" name="3">商品图片</el-tab-pane><el-tab-pane label="商品内容" name="4">商品内容</el-tab-pane></el-tabs></el-form>
这篇关于elementUI浅谈Tag组件的before-leave属性实现条件跳转页面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!