layui中的树形关于取值传值详解

这次给大家带来layui中的树形关于取值传值详解,layui中的树形取值传值的注意事项有哪些,下面就是实战案例,一起来看一下。

本文介绍了layui中的树形关于取值传值问题,分享给大家,具体如下:

layui中的树形关于取值传值详解

这个是我们需要的效果,实际操作中会先执行渲染 然后在执行方法,然后我们发现树形的JSON是空,调试了N遍一直以为是注意事项别的问题了。

最后解决方案是

  ////layui 的 form 模块  var form = "";  layui.use(['form'], function () {    // $ = layui.jquery;    form = layui.form;    //获取节点数据    getTreeData();    //return false;  });  function getTreeData() {    $.ajax({      //async: false,      type: "post",      url: "/api/WebFW//getOrgTree",      datatype: "json",      contenttype: "application/json; charset=utf-8",      success: function (jdata) {        var xtree1 = new layuiXtree({          elem: 'xtree1',          form: form,          data: strToJson(jdata),          isopen: true, //false初始关闭,true打开          click: function (data) { //节点选中状态改变事件监听,全选框有自己的监听事件            console.log(data.elem); //得到checkbox原始DOM对象            console.log(data.elem.checked); //是否选中,true选中            alert(data.value); //弹出value值          }        });        //获取选中val        document.getElementById('btn1').onclick = function () {          var oCks = xtree1.GetChecked();          for (var i = 0; i < oCks.length; i++) {            alert(oCks[i].value);          }        }        //子节点选中改变,父节点更改自身状态        layuiXtree.prototype.ParendCheck = function (ckelem) {          var _this = this;          var xtree_p = ckelem.parentNode.parentNode;          if (xtree_p.getAttribute('class') == 'layui-xtree-item') {            var xtree_all = _this.getChildByClassName(xtree_p, 'layui-xtree-item');            var xtree_count = 0;            for (var i = 0; i < xtree_all.length; i++) {              if (_this.getChildByClassName(xtree_all[i], 'layui-xtree-checkbox')[0].checked) {                xtree_count++;              }            }            if (xtree_count <= 0) {              _this.getChildByClassName(xtree_p, 'layui-xtree-checkbox')[0].checked = false;              _this.getChildByClassName(xtree_p, 'layui-xtree-checkbox')[0].nextSibling.classList.remove('layui-form-checked');            } else {              _this.getChildByClassName(xtree_p, 'layui-xtree-checkbox')[0].checked = true;              _this.getChildByClassName(xtree_p, 'layui-xtree-checkbox')[0].nextSibling.classList.add('layui-form-checked');            }            this.ParendCheck(_this.getChildByClassName(xtree_p, 'layui-xtree-checkbox')[0]);          }        }        //渲染之前按照选中的末级去改变父级选中状态        layuiXtree.prototype.ParentCheckboxChecked = function (e) {          var _this = this;          if (e.parentNode.parentNode.getAttribute('class') == 'layui-xtree-item') {            var _pe = _this.getChildByClassName(e.parentNode.parentNode, 'layui-xtree-checkbox')[0];            _pe.checked = true;            _this.ParentCheckboxChecked(_pe);          }        }        //获取全部选中的末级checkbox对象        layuiXtree.prototype.GetChecked = function () {          var _this = this;          var arr = new Array();          var arrIndex = 0;          var cks = _this.getByClassName('layui-xtree-checkbox');          for (var i = 0; i < cks.length; i++) {            if (cks[i].checked && cks[i].getAttribute('data-xend') == '1') {              arr[arrIndex] = cks[i];              arrIndex++;            }          }          return arr;        }        //获取全部的原始checkbox对象        layuiXtree.prototype.GetAllCheckBox = function () {          var _this = this;          var arr = new Array();          var arrIndex = 0;          var cks = _this.getByClassName('layui-xtree-checkbox');          for (var i = 0; i < cks.length; i++) {            arr[arrIndex] = cks[i];            arrIndex++;          }          return arr;        }        //根据值来获取其父级的checkbox原dom对象        layuiXtree.prototype.GetParent = function (a) {          var _this = this;          var cks = _this.getByClassName('layui-xtree-checkbox');          for (var i = 0; i < cks.length; i++) {            if (cks[i].value == a) {              if (cks[i].parentNode.parentNode.getAttribute('id') == _this._container.getAttribute('id')) return null;              return _this.getChildByClassName(cks[i].parentNode.parentNode, 'layui-xtree-checkbox')[0];            }          }          return null;        }      }    });  }  function strToJson(str) {    var json = (new Function("return " + str))();    return json;  }

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

注意事项

注意事项

注意事项

以上就是layui中的树形关于取值传值详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2782584.html

(0)
上一篇 2025年3月8日 16:33:36
下一篇 2025年3月8日 16:33:42

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • jQuery的复选框选择并且获取值

    这次给大家带来jquery的复选框选择并且获取值,jquery复选框选择并且获取值的注意事项有哪些,下面就是实战案例,一起来看一下。 一、checkbox选择 在jQuery中,选中checkbox通用的两种方式: $(“#cb1”).at…

    2025年3月8日
    200
  • layui select如何动态添加option

    这次给大家带来layui select如何动态添加option,layui select动态添加option的注意事项有哪些,下面就是实战案例,一起来看一下。 html 产品类别 轻松融 容易融 快乐融 增加产品类别 登录后复制 js //…

    编程技术 2025年3月8日
    200
  • 用checkbox操作layui表格

    这次给大家带来用checkbox操作layui表格,用checkbox操作layui表格的注意事项有哪些,下面就是实战案例,一起来看一下。 在之前的版本,默认注意事项是要有值得,默认为“勾选”两个字,在表格里用来做选择不适合,很难改,还好l…

    编程技术 2025年3月8日
    200
  • 关于js的规范

    本篇文章给大家分享的内容是关于js的规范 问题,具有一定的参考价值有需要的朋友可以参考一下 目录 嵌入规则 对齐缩进与换行 命名 声明 类型 对象 数组 字符串 函数 属性 变量 条件表达式和等号 块 注释 空白 逗号 分号 类型转换 命名…

    编程技术 2025年3月8日
    200
  • jquery layui弹出层使用详解

    这次给大家带来jquery layui弹出层使用详解,jquery layui弹出层使用的jquery有哪些,下面就是实战案例,一起来看一下。 Jquery必须大于1.83 layui必须是all,否则不显示 登录后复制 html代码 登录…

    编程技术 2025年3月8日
    200
  • layui实现动态和静态分页

    本篇文章通过实例给大家分享了layui实现动态和静态分页的详细方法,以及效果展示,有需要的朋友可以跟着参考学习下。 开发管理后台是每一个开发人员都要熟悉的一个环节,作为后端程序员,公司的所有机密数据都掌握在我们手上,所以这个时候,如果不是公…

    2025年3月8日
    200
  • layui动态与静态分页实现步骤详解

    这次给大家带来layui动态与静态分页实现步骤详解,layui动态与静态分页实现的注意事项有哪些,下面就是实战案例,一起来看一下。 开发管理后台是每一个开发人员都要熟悉的一个环节,作为后端程序员,公司的所有机密数据都掌握在我们手上,所以这个…

    2025年3月8日
    200
  • Ajax的原生实现关于MIME类型的使用方法(图文教程)

    下面我就为大家分享一篇ajax的原生实现关于mime类型的使用方法,具有很好的参考价值,希望对大家有所帮助。 问题描述 下面的例子是一个Ajax的post请求的代码,这段代码在测试运行的时候,发现返回的状态码为400,服务器不能理解的请求,…

    编程技术 2025年3月8日
    200
  • layui之select的option叠加问题的解决方法

    下面我就为大家分享一篇layui之select的option叠加问题的解决方法,具有很好的参考价值,希望对大家有所帮助。 我在使用layui,在select的地方遇到了坑,select里的值居然无法清空,select里的option还有叠加…

    编程技术 2025年3月8日
    200
  • layui select动态添加option的实例

    下面我就为大家分享一篇layui select动态添加option的实例,具有很好的参考价值,希望对大家有所帮助。 html 登录后复制       js //重新渲染表单function renderForm(){ layui.use(‘…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论