layui弹窗间的传值(layui弹出层传值)(窗口传值)[通俗易懂]

layui弹窗间的传值(layui弹出层传值)(窗口传值)[通俗易懂]主要有两部分1、从主窗口传值到弹出层2、从弹出层传值到主窗口1、从主窗口传值到弹出层首先时jschangefileone函数时按钮绑定事件,按钮点击后调用这个函数然后弹出弹出层,加载changefile.html界面然后success提前加载changefile的form数据(从主窗口传值到弹出层)//bootstraptable的修改,点击按钮的时候自动选中该行,因此可以获取到整行…

大家好,又见面了,我是你们的朋友全栈君。

主要有两部分
1、从主窗口传值到弹出层
2、从弹出层传值到主窗口
3、通过session互传
4、通过调用父窗口的函数从而获取到父窗口的值(相反也是可以的)

1、从主窗口传值到弹出层

首先时js
changefileone函数时按钮绑定事件,按钮点击后调用这个函数然后弹出弹出层,加载changefile.html界面
然后success提前加载changefile的form数据(从主窗口传值到弹出层)

//bootstraptable的修改,点击按钮的时候自动选中该行,因此可以获取到整行的值
function changefileone() { 
   
    var rowselect = $("#menuTable").bootstrapTable('getSelections');   //取得当前选定的selectItem对象,其中包括整行值
    console.log(rowselect);
    layer.open({ 
   
        title: "修改文件属性",
        type: 2,
        content: "changefile.html",
        area: ['50%', '70%'],
        skin: "layui-layer-molv",
        btn: ['确定', '关闭'],
        success: function (layero, index) { 
       //成功获得加载changefile.html时,预先加载,将值从父窗口传到 子窗口
             console.log(obj.data.editAble);
            let body = layer.getChildFrame('body', index);
            //console.log(rowselect[0].filename);
            body.find(".filename").val(rowselect[0].filename);   //通过class名进行获取数据
            body.find(".filepath").val(rowselect[0].path);//意思是将rowselect[0].path这个值传递到子窗口的class="filepath"这个的文本框中,(预先加载)
            //body.find(".menuid").val(rowselect[0].previousid);
            layui.form.render();
        },


        yes: function (index, layero) { 
            //按了弹出层的确定按钮时,这是将在父窗口中获取子窗口form标签里的所有值,并根据name名和值形成键值对json对象
            //console.log(layero);
            layer.alert('来到这里了'+index);
            let body = layer.getChildFrame("body", index);
            let data = { 
   };
            body.find("#changefileform").serializeArray().forEach(function (item) { 
       //获取弹出层写下的数据,input,下拉框啊,之类的表单元素(即changefileform下的所有数据)

                data[item.name] = item.value;   //根据表单元素的name属性来获取数据

            });
            data["fileid"] = rowselect[0].fileid;
            //if (data["previousid"] == "" || data["previousid"] == null)
            // data["previousid"] = rowselect[0].previousid;
            console.log(data);
            $.post('/api/dofile', data, function (result) { 
   
                if (result == "success") { 
   
                    layer.alert("修改文件属性成功");
                }

                setTimeout(function () { 
   
                    layer.close(index);
                    parent.location.reload();
                }, 600);
            });

            layer.close(index);
            resetSearch();
        }
    });
    
}

在这里插入图片描述
点击按钮后,提前加载在这里插入图片描述

然后是html界面,script里面是用来下拉框加载数据库数据的,可以删掉

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <script src="/Scripts/jquery/jquery.min.js" type="text/javascript"></script>
    <script src="/Scripts/layer/layer.js" type="text/javascript"></script>
    <script src="/Scripts/layui/layui.all.js" type="text/javascript"></script>
    <link rel="stylesheet" href="/Scripts/layui/css/layui.css" />
    <script type="text/javascript"> $(document).ready(function () { 
     var selectvalue = ""; //定义这个用来存放选择的value layui.use('form', function () { 
     var form = layui.form; $.get("/api/choosemenu", function (data) { 
     for (var j in data.rows) { 
     //alert(data.rows[j].Name); $("#menuname").append("<option value='" + data.rows[j].menuid + "'>" + data.rows[j].Name + "</option>"); } form.render(); form.on('select', function (data) { 
     //alert(data.value); //console.log(data.value); selectvalue = data.value; console.log(selectvalue); }); }) }) }) </script>
</head>
<body>
    <form class="layui-form" id="changefileform">
        <!-- 提示:如果你不想用form,你可以换成div等任何一个普通元素 -->
        <div class="layui-form-item">
            <label class="layui-form-label layui-bg-red layui-center">文件名</label>
            <div class="layui-input-block">
                <input type="text" name="filename" placeholder="请输入" autocomplete="off" class="layui-input filename">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label layui-bg-red layui-center">文件路径</label>
            <div class="layui-input-block">
                <input type="text" name="filepath" placeholder="请输入" autocomplete="off" class="layui-input filepath">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label layui-bg-green layui-center">父目录</label>
            <div class="layui-input-block">
                <select name="previousid" id="menuname" lay-search>
                    <option value="" style="width:50px" class="menuid">请选择父目录</option>
                </select>

            </div>
        </div>
    </form>

</body>

</html>

2、然后再这个弹出层填写数据,按了确定后就开始加载这个js啦,这个获取数据是通过name属性来获取的,上面 那个的话是通过class名称来获取的
在这里插入图片描述
然后controller获取从js传来的数据的话,看我另外的博客
下拉框动态获取数据库数据
下拉框可以搜索
看我其他博客

3、通过session传值

设置session

sessionStorage.setItem('roleid', 'hello');

取session

var ss=sessionStorage.getItem('roleid');

删除session中保存指定的值

sessionStorage.removeItem('roleid');

删除全部

sessionStorage.clear();

4、通过调用父窗口的函数从而获取到父窗口的值, 这个适合获取少量值, 父窗口的js:

(1)(这个是获取bootstraptable的选定值)menuTable是表格的id,这样返回的值是jSON值来的

function getrowselect() { 
   
    return $.map($('#menuTable').bootstrapTable('getSelections'), function (row) { 
   
        return row//返回数据行
    });
}

(2)如果是普通的text文本框(父窗口的js)

function getrowselect() { 
   
    return $.map($('#text').val(), function (row) { 
   
        return row//返回数据行
    });
}

(3)也可以直接在子窗口的js

window.parent.getElementById("text").val();

如果是(1)(2)种的话子窗口js这样调用(这个是接(1)(2)的啊别搞错了):

 var rowselect = window.parent.getrowselect();
 console.log(rowselect);//这里可以打印一下获取到值没有

5、假如是子窗口传值给父窗口

父窗口js:

function getrowselect(userdata) { 
   
    console.log(userdata);
    document.getElementById(userdata.inputid).value = userdata.uname;
    var dffff = "id" + userdata.inputid;
    document.getElementById(dffff).value=userdata.uid;
    return;
            }

子窗口:

//data="";
//data={"ss"="hello","gg"="world"}
window.parent.getrowselect(data);

6、假如子弹窗窗口想要比父窗口大的话,需要用到top.layer.open或者parent.layer.open
这时通过

var iframeWin = window[layero.find('iframe')[0]['name']]; //得到iframe页的窗口对象,执行iframe页的方法:iframeWin.method();
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131259.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月12日 下午5:36
下一篇 2022年6月12日 下午5:46


相关推荐

  • lamp配置python_LAMP环境搭建

    lamp配置python_LAMP环境搭建这周尝试了 LAMP 环境的搭建 虽然遇到问题 跌跌撞撞 大体上还是完成了搭建 一 了解 1 LAMP 就是 linux 操作系统 apache web 服务器软件 mysql 数据库 php 编程语言 的架构简称 注 M 有时也代表 MariaDB P 有时代表 perl 或 python 2 使用者可以在该环境下开发网站 LAMP 的四个组件都是开源的 所以该组合受到了极大的欢迎 二 行动 1 安装 A

    2026年3月26日
    2
  • 令牌桶 java_服务限流(自定义注解令牌桶算法)

    令牌桶 java_服务限流(自定义注解令牌桶算法)服务限流自定义注解基于 RateLimiter 实现接口限流令牌桶限流算法图片来自网上令牌桶会以一个恒定的速率向固定容量大小桶中放入令牌 当有浏览来时取走一个或者多个令牌 当发生高并发情况下拿到令牌的执行业务逻辑 没有获取到令牌的就会丢弃获取服务降级处理 提示一个友好的错误信息给用户 2 RateLimiter 简单实现 maven 依赖 com google guavaguava18 0 本人使用的

    2026年3月26日
    2
  • java键盘钩子_java 写的低级鼠标键盘钩子示例

    java键盘钩子_java 写的低级鼠标键盘钩子示例需要到http://java.net/projects/jna/downloads下载jna.jar和platform.jar(参考http://my.oschina.net/penngo/blog/12356):1.[代码][Java]代码packagejna_test;importcom.sun.jna.platform.win32.*;importcom.sun.jna.plat…

    2022年5月6日
    46
  • Windows10下python pip卸载并重新安装

    Windows10下python pip卸载并重新安装pip已经升级到最新版本,但还是会提示我在使用旧版本,所以把pip卸载并重新安装一次,之后就没有再提示升级了卸载pip中间会有一个提示,输入Y即可python-mpipuninstallpip找到python所在的目录,进入到子目录Scripts中,打开cmd,输入以下命令:easy_inatall-Upip这样就会重新安装pip并升级到最新版本。再进行pipinstall时候也不会提示升级了。…

    2022年10月19日
    3
  • QTabWidget的样式「建议收藏」

    QTabWidget的样式「建议收藏」Tab标签所在行的样式QTabWidget::tab-bar{alignment:left;top:3px;left:5px;right:5px;}设置QTabWidget的Tab标签下面窗格的样式QTabWidget#tabwidget_DevMang::pane{border-top:3pxsolidblack;border-…

    2026年2月25日
    4
  • 词法分析器(分析C语言)

    词法分析器(分析C语言)问题描述 用 C 或 C 语言编写一个简单的词法分析程序 扫描 C 语言小子集的源程序 根据给定的词法规则 识别单词 填写相应的表 如果产生词法错误 则显示错误信息 位置 并试图从错误中恢复 简单的恢复方法是忽略该字符 或单词 重新开始扫描 相关词法规则标识符 字母标识符 标识符字母标识符 标识符数字常量 无符号整数无符号整

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号