element 级联 父传子

html代码例子

父组件

复制代码
	<el-cascader
		style="width: 100%"
		@change="unitIdChange"
		:options="unitOptions"
		filterable
		v-model="formInline.unitId"
		:props="unitProps"
	    />
	</el-form-item>
	//改变级联传值到这个组件里面
	<resource-view :resourceList="formInline.resourceList" ref="resourceRef"></resource-view>

子组件

复制代码
	<el-form label-position="right" label-width="auto" :model="formData" :disabled="flag == '1'" :rules="rules" ref="addRef">
		<el-table :data="resourceList" style="width: 100%; margin: 10px 0" max-height="250" border>
			<el-table-column fixed prop="ipAddr" label="IP地址" width="250">
				<template #default="{ row, $index }">
					<el-form-item style="width: 100%" :prop="`resourceList.${$index}.ipAddr`" :rules="rules.ipAddr">
						<el-input type="text" :disabled="flag == '1'" placeholder="输入IP地址" v-model="row.ipAddr"></el-input>
					</el-form-item>
				</template>
			</el-table-column>
			<el-table-column prop="locationAreaId" label="所在网络区域">
				<template #default="{ row, $index }">
					<el-form-item :prop="`resourceList.${$index}.locationAreaId`" style="width: 100%">
						<el-tree-select
							style="width: 100%"
							:disabled="flag == '1'"
							v-model="row.locationAreaId"
							:data="locationAreaIdOptions"
							node-key="networkId"
							:render-after-expand="false"
							:check-strictly="true"
							:props="networkIdProps"
						/>
					</el-form-item>
				</template>
			</el-table-column>
			<el-table-column prop="cloudPlatformId" label="所属云平台">
				<template #default="{ row, $index }">
					<el-form-item :prop="`resourceList.${$index}.cloudPlatformId`" style="width: 100%">
						<el-tree-select
							style="width: 100%"
							:disabled="flag == '1'"
							v-model="row.cloudPlatformId"
							:data="cloudPlatformIdOptions"
							node-key="cloudId"
							:render-after-expand="false"
							:check-strictly="true"
							:props="cloudProps"
						/>
					</el-form-item>
				</template>
			</el-table-column>
			<el-table-column prop="applicationId" label="系统项目">
				<template #default="{ row, $index }">
					<el-form-item :prop="`resourceList.${$index}.applicationId`" style="width: 100%">
						<el-select :disabled="flag == '1'" v-model="row.applicationId" style="width: 100%" placeholder="请选择">
							<el-option v-for="item in applicationOptions" :key="item.value" :label="item.label" :value="item.value" />
						</el-select>
					</el-form-item>
				</template>
			</el-table-column>
			<el-table-column fixed="right" label="操作" width="120" v-if="!flag">
				<template #default="scope">
					<el-button link type="danger" size="small" @click.prevent="deleteRow(scope.$index)"> 删除 </el-button>
				</template>
			</el-table-column>
		</el-table>
	</el-form>
	<el-button v-if="!flag" class="mt-4" style="width: 100%; margin-bottom: 10px" @click="onAddItem">添加</el-button>
</template>

ts

复制代码
// 设置级联选择器的属性
const unitProps = {
	checkStrictly: true,//是否严格的遵守父子节点不互相关联
	emitPath: false,//是否返回数组
	filterable: true//是否可以搜索
};
//改变级联的值并且传值
const unitIdChange = (val: any) => {
//传true为新增,false为编辑
	resourceRef.value.getApplyList(val, true);
};

子组件接收的方法
//获取应用系统
const getApplyList = (val: any, isChange: any) => {
	//判断是否是change,是change才清空
	if (isChange) {
		resourceList.value = resourceList.value.map((item: any) => {
			item.applicationId = "";
			return item;
		});
	}
	getApplyListByUnitId(val).then((res: any) => {
		applicationOptions.value = res.data;
	});
};

例子展示

单位级联展示

根据单位加载系统项目

相关推荐
devincob4 小时前
js原生、vue导出、react导出、axios ( post请求方式)跨平台导出下载四种方式的demo
javascript·vue.js·react.js
木头没有瓜6 小时前
在 Windows 中清理依赖node_modules并重新安装
vue.js
不吃香菜的猪6 小时前
el-upload实现文件上传预览
前端·javascript·vue.js
dcloud_jibinbin7 小时前
【uniapp】小程序体积优化,分包异步化
前端·vue.js·webpack·性能优化·微信小程序·uni-app
qq_427506087 小时前
基于Vue 3和Element Plus实现简单的钩子函数管理各类弹窗操作
前端·javascript·vue.js
六月的可乐10 小时前
实战干货-Vue实现AI聊天助手全流程解析
前端·vue.js·ai编程
一 乐11 小时前
智慧党建|党务学习|基于SprinBoot+vue的智慧党建学习平台(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·学习
暴富的Tdy12 小时前
【基于 WangEditor v5 + Vue2 封装 CSDN 风格富文本组件】
vue.js·wangeditor·富文本
开发者小天12 小时前
React中的componentWillUnmount 使用
前端·javascript·vue.js·react.js
永远的个初学者13 小时前
图片优化 上传图片压缩 npm包支持vue(react)框架开源插件 支持在线与本地
前端·vue.js·react.js