需求背景
现在有一个需求,就是需要在当前项目的一个页面中嵌套其他系统通过接口API返回的一个页面,首先考虑的就是 iframe 嵌套页面,于是就在当前页面尝试了一下,效果还是不错的。
页面操作
首先需要在父页面引入一个 iframe 标签,用于放置接口传过来的页面
<iframe id="tab1" width="100%" height="300"></iframe>
其中,参数 width 用来设置 iframe 的宽度, height 用来设置 iframe 的高度。
页面 js 代码如下
//基础信息 tab function tab1() { console.log("tab1 click"); var url = prefix+"/toIframe?id=1&name=张三"; $('#tab1').attr("src",url); }
这里的 tab1 方法是为 tab 绑定的一个方法,你可以简单的理解为一个按钮,当点击按钮后,就会为指定的 iframe 嵌套页面。
iframe 后面的拼接参数 ?id=1&name=张三 就是在嵌套页面需要接收到参数。
后端代码
在后端 controller 添加方法,并返回待 iframe 嵌套的页面,
"/toIframe") (public String getIframe(HttpServletRequest request,ModelMap mmap) { String id = request.getParameter("id"); mmap.put("id",id); String name = request.getParameter("name"); mmap.put("name",name); return prefix + "/iframe"; }
待嵌套的子页面代码 iframe.html 代码如下
<html lang="en"> <head> <meta charset="UTF-8"> <title>title</title> </head> <body> <h2>这是一个嵌套页面,参数id:[[${id}]],name:[[${name}]]</h2> </body> </html>
那么前端页面代码及后端页面代码都准备好之后,启动项目,我们来看一下效果
当然,如果你想在 js 方法中动态控制 iframe 的宽高,可以如下更改按钮点击事件绑定的方法 tab1()
//基础信息 tab function tab1() { console.log("tab1 click"); var url = prefix+"/toIframe?id=1&name=张三"; $('#tab1').attr("src",url); $('#tab1').attr("width",500); $('#tab1').attr("height",500); }
效果如图
或者也可以如下更改按钮点击事件绑定的方法 tab1()
//基础信息 tab function tab1() { console.log("tab1 click"); let element = document.getElementById("tab1"); element.width=300; element.height=300; var url = prefix+"/toIframe?id=1&name=张三"; $('#tab1').attr("src",url); }
项目热部署后刷新页面效果如图
总结
总的来说,通过 iframe 嵌套页面的方式可以将通过接口传来的页面完整的嵌入到当前页面中,且页面内容不会受影响导致不能用,这就使得在获取其他系统数据时有了更多的选择,可以直接在其他系统将数据组装成完整页面后传入当前系统嵌套展示,而不是通过接口传输数据,然后在当前页面重新渲染的情况,这样可以很大的提升两边的开发效率,有一定的应用场景。