| | |
| | | </el-checkbox> |
| | | |
| | | <div v-if="treeCenter.length>0"> |
| | | <div v-for="item in treeCenter[0].children" :key="item.menucode"> |
| | | <div v-for="(item,index) in treeCenter[0].children" :key="item.menucode"> |
| | | |
| | | <div |
| | | v-if="item.buttoncodelist ===null " |
| | |
| | | :key="it.menucode" |
| | | v-model="it.buttonChecked" |
| | | style="margin-left: 40px;height:26px;display: flex;" |
| | | @change="val=>handleCheckedButtonChange(val,it.menucode,it.buttonChecked)" |
| | | @change="val=>handleCheckedButtonChange(val,index,it.menucode,it.buttonChecked)" |
| | | > |
| | | |
| | | <el-checkbox |
| | |
| | | |
| | | this.treeLeft = res |
| | | |
| | | if (res.length > 0) { |
| | | if (res && res.length > 0) { |
| | | this.$nextTick(() => { // 默认选中第一个 |
| | | this.$refs.treeLeftRef.setCurrentKey(res[0].roles[0].code) // 默认选中节点第一个 |
| | | }) |
| | |
| | | } |
| | | }) |
| | | |
| | | this.handleCheckedButtonChange('', '', '', true) |
| | | this.handleCheckedButtonChange('', '', '', '', true) |
| | | this.handleCheckedDataChange('', '', true) |
| | | // this.$forceUpdate() |
| | | }, |
| | |
| | | } |
| | | }, |
| | | // 单个按钮改变 |
| | | handleCheckedButtonChange(oldValue, code, newValue, flag) { |
| | | // console.log(oldValue, code, newValue, 2) |
| | | handleCheckedButtonChange(oldValue, index, code, newValue, flag) { |
| | | console.log(oldValue, index, code, newValue, 2) |
| | | // 判断是否包含在内 |
| | | if (!flag) { |
| | | if (!this.menuCheckedCodeArr.includes(code) && oldValue.length === 0 && newValue.length === 1) { // 否 |
| | | this.menuCheckedCodeArr.push(code) |
| | | } else if (this.menuCheckedCodeArr.includes(code) && oldValue.length === 1 && newValue.length === 0) { // 是 |
| | | this.menuCheckedCodeArr = this.menuCheckedCodeArr.filter(i => i !== code) |
| | | // 当数据权限未勾选时则过滤掉相对应的菜单 |
| | | if (this.treeCenter[0].children[index].children.find(i => i.menucode === code).dataChecked.toString().length < 1) { |
| | | this.menuCheckedCodeArr = this.menuCheckedCodeArr.filter(i => i !== code) |
| | | } |
| | | } |
| | | this.$refs.treeCenterRef.setCheckedKeys(this.menuCheckedCodeArr) |
| | | } |
| | |
| | | // 处理中间树形选中值改变 |
| | | handleTreeCenterCheckChange(obj, selfChecked, selfChildrenTreeCheck) { |
| | | // console.log(obj, selfChecked, selfChildrenTreeCheck, '王老吉') |
| | | console.log(selfChecked, 10) |
| | | if (!selfChildrenTreeCheck) { |
| | | if (!selfChecked) { // 从选中到不选中 |
| | | obj.buttonChecked = [] |
| | |
| | | this.menuCheckedCodeArr = this.menuCheckedCodeArr.filter(i => i !== obj.menucode) |
| | | } |
| | | if (selfChecked) { // 从不选中到选中 |
| | | console.log(obj, 9) |
| | | obj.buttonCheckedCode = [] |
| | | this.treeCenter[0].children.forEach(item => { |
| | | if (item.children && item.children.length) { |
| | | item.children.forEach(it => { |
| | |
| | | } |
| | | }) |
| | | } |
| | | |
| | | this.$forceUpdate() |
| | | } |
| | | }, |