百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

layui中弹出层的保存按钮绑定为iframe中表单的按钮

yuyutoo 2025-06-12 18:40 4 浏览 0 评论

弹出层提交表单的js


layer.open({
	type : 2,
	title : '添加权限',
	area : [ '500px', '450px' ],
	offset : '160px',
	shadeClose : true, // 点击遮罩关闭
	btn : ['保存','取消'],
	content : 'permission_add.html',
	success : function(layero, index) { // 成功弹出后回调
		
	},
	yes : function(index, layero) { // 保存按钮回调函数
	    // 获取iframe层的body
	    var body = layer.getChildFrame('body', index);
	    // 找到隐藏的提交按钮模拟点击提交
	    body.find('#permissionSubmit').click();
	},
	btn2 : function(index, layero) { // 取消按钮回调函数
		layer.close(index); // 关闭弹出层
	}
});
	

弹出层表单中隐藏的提交按钮代码

<div class="layui-form-item" hidden>
    <div class="layui-input-block">
        <button id="permissionSubmit" class="layui-btn" lay-submit lay-filter="*">
        保存
        </button>
    </div>
</div>

iframe页面js内容


<script>
  // 初始化表单
  layui.use([  'form',  'layer'  ], function() {
    var  form = layui.form, layer = layui.layer,  $ =  layui.$;
    // 更新页面渲染,否则会造成页面加载元素不完整
     form.render();
    // 自定义表单验证
    form.verify({
      name : function(value, item) { // 验证功能名
        var  defaultName  = $('#defaultName').val(); // 默认的name
        if (value !== defaultName || 'default' === defaultName)  { // 判断功能名字是否发生改变
          if (!new RegExp("^[a-zA-Z0-9|\u4e00-\u9fa5\]{2,10}#34;)
              .test(value)) {
            return '权限名必须是2-10位中英文或者数字的字符';
          } else {
            code = 0; // 用来判断功能名是否存在
            $.ajax({
              type : 'POST',
              url  : 'queryNameIsExist.do',
              data : {
                name : value
              },
              async :  false,
              dataType : 'json',
              success  : function(data) {
                if (!data.success) { //  功能名已经存在
                  code = 1;
                }
              },
              error :  function(data) {
                code = 2;
              }
            });
            // 根据code判断角色名是否存在
            if (code ==  1) {
              return '功能名已经存在,请更换';
            } else if (code  == 2) {
              return '出现异常,请联系管理员';
            }
          }
        }
      },
      url  : function(value, item)  { // 校验功能url
        var  defaultUrl = $('#defaultUrl').val(); //  默认的url
        if (value !== defaultUrl ||  'default' === defaultUrl) {  // 判断功能url是否发生改变
          if (!new RegExp("^[a-zA-Z0-9/]{5,30}#34;).test(value)) {
            return 'url必须是5-30位英文和/组成的字符串';
          } else {
            code = 0; // 用来判断功能url是否存在
            $.ajax({
              type : 'POST',
              url  : 'queryUrlIsExist.do',
              data : {
                name : value
              },
              async :  false,
              dataType : 'json',
              success  : function(data) {
                if (!data.success) { //  功能url已经存在
                  code = 1;
                }
              },
              error :  function(data) {
                code = 2;
              }
            });
            // 根据code判断功能url是否存在
            if (code ==  1) {
              return '功能url已经存在';
            } else if (code  == 2) {
              return '出现异常,请联系管理员';
            }
          }
        }
      },
      permission : function(value, item) { //  校验权限字符串
        var  defaultPermission =  $('#defaultPermission').val(); // 默认的权限字符串
        if (value !== defaultPermission
            || 'default' !== defaultPermission)  { // 判断功能权限字符串是否发生改变
          if (!new RegExp("^[a-zA-Z0-9]{2,20}#34;).test(value))  {
            return '权限字符串必须是2-20位英文字符';
          } else {
            code = 0; // 用来判断功能权限字符串是否存在
            $.ajax({
              type : 'POST',
              url  : 'queryPermissionIsExist.do',
              data : {
                name : value
              },
              async :  false,
              dataType : 'json',
              success  : function(data) {
                if (!data.success) { //  功能权限字符串已经存在
                  code = 1;
                }
              },
              error :  function(data) {
                code = 2;
              }
            });
            // 根据code判断功能权限字符串是否存在
            if (code ==  1) {
              return '功能权限字符串已经存在';
            } else if (code  == 2) {
              return '出现异常,请联系管理员';
            }
          }
        }
      }
    });
 
    // 监听form表单提交
    form.on('submit(save)',  function(data) {
      $.ajax({
        type : 'POST',
        url  : 'createResource.do',
        data : {
          name : $('#name').val(),
          url  : $('#url').val(),
          type : $('input[name]:checked').val(),
          parentId : $('#parentId').val(),
          permission : $('#permission').val(),
          available :  $('#available').is(':checked') === true  ? 1  : 0
        },
        dataType : 'json',
        success  : function(data) {
          // 成功提示框
          parent.layer.msg('添加成功', {
            icon : 6,
          });
          parent.layer.closeAll('iframe'); //关闭弹框
        },
        error :  function(data) {
          // 异常提示
          parent.layer.msg('出现网络故障', {
            icon : 5
          });
          parent.layer.closeAll('iframe'); //关闭弹框
        }
      });
      return false;
    });
  });
</script>

我们只需要在保存按钮的回调函数中获取到iframe页面的隐藏的提交按钮然后使用click()事件就可以提交弹出iframe层的表单了,表单验证和表单提交都在iframe页面的js中,iframe页面的js中需要注意的是弹窗操作需要操作父页面的layer来进行

相关推荐

从零搭建高可用的 MySQL 主从复制架构(基于 Linux 实战指南)

背景在生产环境中,单点MySQL数据库容易成为性能瓶颈或单点故障源。搭建MySQL主从复制架构,可以实现读写分离、高可用,提升系统的整体稳定性与扩展性。...

国外大神成功让Nexus4吃上安卓6.0:基本可正常使用

IT之家讯10月9日消息谷歌已经于10月6日正式开启了Nexus设备Android6.0Marshmallow系统的OTA升级推送。根据之前报道的消息,老一批的Nexus手机如Nexus4/Ne...

急死!CPU被挖矿了,却找不到哪个进程

CPU起飞了最近有朋友在群里反馈,自己服务器的CPU一直处于高占用状态,但用...

甜甜的安卓5.0却让手机ROOT难度大大增加

IT之家(www.ithome.com):甜甜的安卓5.0却让手机ROOT难度大大增加对设备进行ROOT,毫无疑问,这是安卓最美丽的地方之一,不管是对于消费者来说还是开发者。Root意味着掌握更多的权...

Linux基础知识(linux基础知识点及答案)

系统目录结构/bin:命令和应用程序。/boot:这里存放的是启动Linux时使用的一些核心文件,包括一些连接文件以及镜像文件。/dev:dev是Device(设备)的缩写,该目录...

Linux 内核 6.15 发布:内存、网络、文件系统全面升级!

核心增强:性能与安全双飞升!Linux内核6.15的正式版!虽然因一个临门一脚的Bug晚了几小时,但最终还是带着一堆硬核更新闪亮登场!...

AlmaLinux 9.6 发布,新增功能亮点纷呈!

距离上一版本AlmaLinux9.5发布六个月后,基于5.14内核的AlmaLinux正式宣布其企业级Linux发行版的9.x系列第六个更新——AlmaLinux9.6(Sag...

理解Linux下的SELinux(linux seccomp)

理解Linux下的SELinux长久以来,每当遇到授权问题或者新安装的主机,我的第一反应是通过setenforce0命令禁用SELinux,来减少产生的权限问题,但是这并不是一个良好的习惯。这篇文章...

3个简单实用的网址导航网站(简洁的网站导航)

在我们使用电脑上网的时候经常会访问某些常用的网站,每一次都去通过搜索访问就比较浪费时间,添加在浏览器收藏夹不方便在其他电脑使用。找一个好用的网址导航网站就可以帮我们把所有常用的网址集合在一个页面,方便...

整点不一样的网站制作教程,教你怎么用网站模板制作网站#...

网站制作教程整点不一样的网站。不要再问我网站制作教程了,今天给你整个怎么用网站模板制作网站的教程。·1、登录账号进入后台。·2、选择模板。自助建站平台通常提供各种各样的网站模板,可以根据自己的需求和喜...

5个最好的外贸独立站模板,让你的网站更加专业

作为外贸行业从业者,一个专业且具有吸引力的网站是必不可少的。然而,建立一个专业的网站需要耗费大量的时间和精力,尤其是在设计和开发方面。为了帮助您缩短网站建设的时间和成本,以下是5个最好的外贸独立站模板...

网站建设模板 **网站建设模板:全面指南与创意构思*

网站建设模板**网站建设模板:全面指南与创意构思**随着互联网技术的迅猛发展,网站已成为企业、机构和个人展示自身形象、传递信息、实现交流的重要平台。本文将详细介绍网站建设的基本模板,并提供创意...

原地封神!一个只用套模板即可制作电子相册的网站

对于忙碌的年轻人来说,一键操作的模板意味着无需复杂的操作步骤,就能轻松制作出精美的电子相册。但是一个好的工具也是事关重要,最近发现了一款非常适合年轻人的模板---FLBOOK在线制作电子杂志平台,只需...

跨屏建站网kpfree免费网站模板2023.1.14发布更新

跨屏建站网kpfree免费网站模板2023.1.14发布更新,摒弃了之前的卡片式设计,采用了移动优先的设计原则,简化了页面设计风格,优化了代码,优化了图片质量,确保网页打开速度。砍掉了一些花哨而无用的...

响应式大型电子企业集团类网站模板源码-青柠资源网qnziyw.cn

模板信息:模板编号:10964模板编码:UTF8模板颜色:红色模板分类:科技、电子、数码设备适合行业:电子设备类企业模板介绍:本模板自带eyoucms内核,无需再下载eyou系统,原创设计、手工书写D...

取消回复欢迎 发表评论: