el-cascader添加全选功能-多级

104 篇文章 0 订阅

在这里插入图片描述
在这里插入图片描述

  <el-cascader class="myCascader" :options="areaData" :props="regionalInfosProps" collapse-tags clearable  v-model="editDepartmentForm.regionalInfos"  @change="changecascader($event,'edit')" popper-class="cascader-department cascaderOwner" size="small" ref="cascaderOwner" @expand-change="cascaderToscroll('cascaderOwner')" style="width:456px"  filterable></el-cascader>
data   数据说明
istype: ''  判断是新建还是编辑

addDepartmentForm{
  regionalInfos  // 后台需要数据 因为是对象格式 使用 this.$set  赋值
}
deepOptionData:【】  暂时存放数据 使数据变为  [  [100], [101,1011] ]
deepOptionDataCopy :[]  通过监听此数据 -- 改变需要给后台的值
  • 思路
  • 使用change事件–
  • hasAll 定义 数据中是否有全选
  • isSelectAll 定义全选是否呗选中
  • hasAll && !isSelectAll 点击全选 --下面都勾选上
  • (!hasAll && this.isSelectAll) 取消选择全部
  • (!hasAll && !this.isSelectAll) // 反勾选全部
  • hasAll && this.isSelectAll) { // 勾中全部时 然后取消下面的勾选 全部取消掉
 changecascader(val, type) {
      this.istype = type
      let hasAll = val[0][0] === 10000000 // 全选定义值 10000000
    
        if (hasAll && this.isSelectAll) { // 勾中全部 然后取消下面的勾选 全部取消掉
          this.$refs.cascaderOwner.$refs.panel.clearCheckedNodes() //清空选中的节点	
          val.splice(0, 1) // 删除全选
          this.deepOptionDataCopy = val// 重新定义数据
          this.isSelectAll = false // 全选文字状态改变
          this.goall = false
        } else if (hasAll && !this.isSelectAll) { //选中全部
          this.isSelectAll = true
          this.selectAll(this.areaData, type)
           this.goall = false
        } else if (!hasAll && this.isSelectAll) { //取消选择全部
          this.isSelectAll = false
          this.$refs.cascaderOwner.$refs.panel.clearCheckedNodes()
          this.deepOptionDataCopy = []
           this.goall = false
        } else if (!hasAll && !this.isSelectAll) { // 反勾选全部
          this.goall = true // 反勾选全部状态 等长度一致 把全部数据放进去
          this.deepOptionDataCopy = val
        }
    },
    selectAll(value) { // 全选操作
      let arr
      
      value.forEach((res) => { // 处理数据为 [  [100], [101,1011] ]
        if (res.children) {
          this.deepOptionData.push(res.value)
          this.selectAll(res.children)
        } else {
          arr = JSON.parse(JSON.stringify(this.deepOptionData))
          arr.push(res.value) // [101,1011]

          this.deepOptionDataCopy.push(arr) // [  [100], [101,1011] ]
        }
      })
      this.deepOptionData = [] // 把 deepOptionData 数据还原
    },



+ 监听改变数据
 watch: {

    deepOptionDataCopy(val) {
      if (val?.length === 351 && val[0][0] != 10000000 && this.goall) { //下面全部勾选的话 全部也勾上
        val = [10000000].concat(val)
        this.isSelectAll = true
      }
      
      if (this.istype === 'new') {
        this.$set(this.addDepartmentForm, 'regionalInfos', val)
      } else {
         this.$set(this.editDepartmentForm, 'regionalInfos', val)
      }
    }
  },
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
删除之类操作需要全选功能,方便选择 public class MainActivity extends Activity { private ListView lv; private MyAdapter mAdapter; private ArrayList list; private Button bt_selectall; // private Button bt_cancel; // private Button bt_deselectall; private int checkNum; // 记录选中的条目数量 private TextView tv_show;// 用于显示选中的条目数量 /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); /* 实例化各个控件 */ lv = (ListView) findViewById(R.id.lv); bt_selectall = (Button) findViewById(R.id.bt_selectall); // bt_cancel = (Button) findViewById(R.id.bt_cancelselectall); // bt_deselectall = (Button) findViewById(R.id.bt_deselectall); tv_show = (TextView) findViewById(R.id.tv); list = new ArrayList(); // 为Adapter准备数据 initDate(); // 实例化自定义的MyAdapter mAdapter = new MyAdapter(list, this); // 绑定Adapter lv.setAdapter(mAdapter); // 全选按钮的回调接口 bt_selectall.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 遍历list的长度,将MyAdapter中的map值全部设为true for (int i = 0; i < list.size(); i++) { MyAdapter.getIsSelected().put(i, true); } // 数量设为list的长度 checkNum = list.size(); // 刷新listview和TextView的显示 dataChanged(); } }); // 反选按钮的回调接口 // bt_cancel.setOnClickListener(new OnClickListener() { // @Override // public void onClick(View v) { // // 遍历list的长度,将已选的设为未选,未选的设为已选 // for (int i = 0; i < list.siz
el-cascader添加全选功能的步骤如下: 1.在el-cascader的数据源中添加全选”选项,例如: ```javascript options: [{ value: 'zhinan', label: '指南', children: [{ value: 'shejiyuanze', label: '设计原则', children: [{ value: 'yizhi', label: '一致' }, { value: 'fankui', label: '反馈' }, { value: 'xiaolv', label: '效率' }, { value: 'kekong', label: '可控' }] }, { value: 'daohang', label: '导航', children: [{ value: 'cexiangdaohang', label: '侧向导航' }, { value: 'dingbudaohang', label: '顶部导航' }] }] }, { value: 'zujian', label: '组件', children: [{ value: 'basic', label: 'Basic', children: [{ value: 'layout', label: 'Layout 布局' }, { value: 'color', label: 'Color 色彩' }, { value: 'typography', label: 'Typography 字体' }, { value: 'icon', label: 'Icon 图标' }, { value: 'button', label: 'Button 按钮' }] }, { value: 'form', label: 'Form', children: [{ value: 'radio', label: 'Radio 单选框' }, { value: 'checkbox', label: 'Checkbox 多选框' }, { value: 'input', label: 'Input 输入框' }, { value: 'input-number', label: 'InputNumber 计数器' }, { value: 'select', label: 'Select 选择器' }, { value: 'cascader', label: 'Cascader 级联选择器' }, { value: 'switch', label: 'Switch 开关' }, { value: 'slider', label: 'Slider 滑块' }, { value: 'time-picker', label: 'TimePicker 时间选择器' }, { value: 'date-picker', label: 'DatePicker 日期选择器' }, { value: 'datetime-picker', label: 'DateTimePicker 日期时间选择器' }, { value: 'upload', label: 'Upload 上传' }, { value: 'rate', label: 'Rate 评分' }, { value: 'form', label: 'Form 表单' }] }] }, { value: 'ziyuan', label: '资源', children: [{ value: 'axure', label: 'Axure Components' }, { value: 'sketch', label: 'Sketch Templates' }, { value: 'jiaohu', label: '组件交互文档' }] }, { value: 'ziyuan1', label: '资源1', children: [{ value: 'axure1', label: 'Axure Components1' }, { value: 'sketch1', label: 'Sketch Templates1' }, { value: 'jiaohu1', label: '组件交互文档1' }] }, { value: 'ziyuan2', label: '资源2', children: [{ value: 'axure2', label: 'Axure Components2' }, { value: 'sketch2', label: 'Sketch Templates2' }, { value: 'jiaohu2', label: '组件交互文档2' }] }, { value: 'ziyuan3', label: '资源3', children: [{ value: 'axure3', label: 'Axure Components3' }, { value: 'sketch3', label: 'Sketch Templates3' }, { value: 'jiaohu3', label: '组件交互文档3' }] }, { value: 'ziyuan4', label: '资源4', children: [{ value: 'axure4', label: 'Axure Components4' }, { value: 'sketch4', label: 'Sketch Templates4' }, { value: 'jiaohu4', label: '组件交互文档4' }] }, { value: 'ziyuan5', label: '资源5', children: [{ value: 'axure5', label: 'Axure Components5' }, { value: 'sketch5', label: 'Sketch Templates5' }, { value: 'jiaohu5', label: '组件交互文档5' }] }] ``` 2.在el-cascader的模板中添加全选按钮,例如: ```html <template> <el-cascader :options="options" :props="props" v-model="selectedOptions" @change="handleChange" @expand-change="handleExpandChange" @visible-change="handleVisibleChange" @remove-tag="handleRemoveTag" @clear="handleClear" :show-all-levels="false" :check-strictly="true" :expand-trigger="expandTrigger" :filterable="filterable" :placeholder="placeholder" :disabled="disabled" :size="size" :popper-class="popperClass" :before-filter="beforeFilter" :debounce="debounce" :change-on-select="changeOnSelect" :popper-append-to-body="popperAppendToBody" :hover-threshold="hoverThreshold" :load-data="loadData" :loading-text="loadingText" :no-match-text="noMatchText" :no-data-text="noDataText" :popper-options="popperOptions" :emit-path="emitPath" :value-consists-of="valueConsistsOf" :collapse-tags="collapseTags" :show-always="showAlways" :clearable="clearable" :expand-trigger-on-focus="expandTriggerOnFocus" :change-on-blur="changeOnBlur" :before-clear="beforeClear" :popper-append-to-body="popperAppendToBody" :popper-options="popperOptions" :filter-method="filterMethod" :reserve-keyword="reserveKeyword" :default-first-option="defaultFirstOption" :popper-class="popperClass" :popper-append-to-body="popperAppendToBody" :popper-options="popperOptions" :before-clear="beforeClear" :before-expand="beforeExpand" :before-select="beforeSelect" :clear-icon="clearIcon" :expand-icon="expandIcon" :loading-icon="loadingIcon" :multiple-limit="multipleLimit" :show-checkbox="showCheckbox" :check-strictly="checkStrictly" :emit-path="emitPath" :lazy="lazy" :lazy-load="lazyLoad" :lazy-method="lazyMethod" :model-value="modelValue" :filter-method="filterMethod" :debounce="debounce" :change-on-select="changeOnSelect" :expand-trigger-on-focus="expandTriggerOnFocus" :change-on-blur="changeOnBlur" :before-clear="beforeClear" :before-expand="beforeExpand" :before-select="beforeSelect" :clear-icon="clearIcon" :expand-icon="expandIcon" :loading-icon="loadingIcon" :multiple-limit="multipleLimit" :show-checkbox="showCheckbox" :check-strictly="checkStrictly" :emit-path="emitPath" :lazy="lazy" :lazy-load="lazyLoad" :lazy-method="lazyMethod" :model-value="modelValue" ref="cascader" > <template #suffix> <el-checkbox v-model="isAllSelected" @change="handleAllSelectedChange" :indeterminate="isIndeterminate" > 全选 </el-checkbox> </template> </el-cascader> </template> ``` 3.在el-cascader的脚本中添加全选相关的逻辑,例如: ```javascript <script> export default { data() { return { options: [{ value: 'zhinan', label: '指南', children: [{ value: 'shejiyuanze', label: '设计原则', children: [{ value: 'yizhi', label: '一致' }, { value: 'fankui', label: '反馈' }, { value: 'xiaolv', label: '效率' }, { value: 'kekong', label: '可控' }] }, { value: 'daohang', label: '导航', children: [{ value: 'cexiangdaohang', label: '侧向导航' }, { value: 'dingbudaohang', label: '顶部导航' }] }] }, { value: 'zujian', label: '组件', children: [{ value: 'basic', label: 'Basic', children: [{ value: 'layout', label: 'Layout 布局' }, { value: 'color', label: 'Color 色彩' }, { value: 'typography', label: 'Typography 字体' }, { value: 'icon', label: 'Icon 图标' }, { value: 'button', label: 'Button 按钮' }] }, { value: 'form', label: 'Form', children: [{ value: 'radio', label: 'Radio 单选框' }, { value: 'checkbox', label: 'Checkbox 多选框' }, { value: 'input', label: 'Input 输入框' }, { value: 'input-number', label: 'InputNumber 计数器' }, { value: 'select', label: 'Select 选择器' }, { value: 'cascader', label: 'Cascader 级联选择器' }, { value: 'switch', label: 'Switch 开关' }, { value: 'slider', label

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值