根据table数据监听行事件请求后端返回给ajax的数据显示在layui弹出层iframe中

实现思路

layui监听 table行事件调用ajax请求并将点击的行的数据发送给控制器,由控制器调用后端业务得到结果将结果放入session,由ajax 回调函数success open一个type为2(即iframe)的弹出层,content属性为控制器链接,弹出层请求的控制器返回一个jsp页面,在jsp页面中获取并显示之前存入session中的数据。

主页面.js

//监听行单击事件(双击事件为:rowDouble)
table.on('row(unreadMessage)', function(obj){
    var data = obj.data;
    $.ajax({
        type: 'POST',
        url: '/stu-info_manage/getTransactionDetail',//发送请求
        data: {
            messageId:data.messageId,
        },
        success: function(result) {
            layer.open({
                type: 2,//弹出框类型
                shift:1,//弹出框动画效果
                closeBtn: 0, //不显示关闭按钮
                anim: 5,
                shadeClose: true, //开启遮罩关闭
                title:'事务信息',
                area : ['60%' , '90%'],
                shift:1,
                content:'/stu-info_manage/transactionDetail'//将结果页面放入layer弹出层中

            });
        }
    });

Controller

   //事务详情弹出层
    @RequestMapping("/getTransactionDetail")
    @ResponseBody
    public String getTransactionDetail(HttpServletRequest request,
                                           @RequestParam("messageId") int messageId) {
        String content;
        try {
            //创建session对象
            HttpSession session = request.getSession();
            //把数据保存在session域对象中
            session.setAttribute("messageId", messageId);
            content=ykyService.queryMessageContent(messageId);
            session.setAttribute("messageContent", content);
            if(session==null||"".equals(messageId+"")){
                //没有登录成功,跳转到登录页面
                return "redirect:/";    //返回首页
            }
        }catch (Exception e){
            return "redirect:/";
        }
        return content;
    }
    //加载事务内容页面
    @RequestMapping("/transactionDetail")
    public String transactionDetail(HttpServletRequest request) {
        try {
            //创建session对象
            HttpSession session = request.getSession();
            //取出会话数据
            String id = (String) session.getAttribute("id");
            System.out.println("id==="+id);
            if(session==null||id==null){
                //没有登录成功,跳转到登录页面
                return "redirect:/";    //返回首页
            }
        }catch (Exception e){
            return "redirect:/";
        }
        return "TransactionDetail";
    }

弹出层iframe加载的jsp页面(部分)

<script>
    var messageContent='${sessionScope.messageContent}';
</script>
<body>
<div class="layui-bg-gray" style="padding: 30px;">
    <div class="layui-row layui-col-space15">
        <div class="layui-col-md6">
            <div class="layui-panel">
                <div style="padding: 50px 30px;" id="messageContent"></div>
            </div>
        </div>
    </div>
</div>
<script>
    $("#messageContent").text(messageContent);
</script>
</body>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值