快速实现 iframe 嵌套页面

快速实现 iframe 嵌套页面

需求背景

现在有一个需求,就是需要在当前项目的一个页面中嵌套其他系统通过接口API返回的一个页面,首先考虑的就是 iframe 嵌套页面,于是就在当前页面尝试了一下,效果还是不错的。

页面操作

首先需要在父页面引入一个 iframe 标签,用于放置接口传过来的页面

html 复制代码
<iframe id="tab1" width="100%" height="300"></iframe>

其中,参数 width 用来设置 iframe 的宽度, height 用来设置 iframe 的高度。

页面 js 代码如下

javascript 复制代码
//基础信息 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 嵌套的页面,

java 复制代码
@RequestMapping("/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 复制代码
<!DOCTYPE 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()

javascript 复制代码
//基础信息 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()

javascript 复制代码
//基础信息 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 嵌套页面的方式可以将通过接口传来的页面完整的嵌入到当前页面中,且页面内容不会受影响导致不能用,这就使得在获取其他系统数据时有了更多的选择,可以直接在其他系统将数据组装成完整页面后传入当前系统嵌套展示,而不是通过接口传输数据,然后在当前页面重新渲染的情况,这样可以很大的提升两边的开发效率,有一定的应用场景。

相关推荐
MXN_小南学前端14 小时前
Vue + Element UI 分页器封装:比直接用 el-pagination 更省心的通用方案
javascript·vue.js·elementui
Lkstar14 小时前
ES6+ 必备特性复习:解构、展开运算符、Symbol、Proxy
javascript·面试
半兽先生14 小时前
vue高性能下拉组件 支持上万数据不卡顿
前端·javascript·vue.js
invicinble14 小时前
前端框架使用vue-cli( 第二层:工程配置层--路由页面配置)
javascript·vue.js·前端框架
四岁爱上了她14 小时前
自定义标签切换动画
javascript·css·css3
普修罗双战士14 小时前
专业Markdown转HTML工具类:修复优化与Spring Boot适配
windows·spring boot·html
坤盾科技14 小时前
Docker 离线地图服务器搭建实战:Node.js + OpenLayers + MBTiles
linux·javascript·arcgis·docker·node.js
Copy_Paste_Coder15 小时前
小程序失败后,换个方向,终于成功搞到收益
前端·javascript·后端
ZC跨境爬虫15 小时前
跟着 MDN 学 HTML day_31:(AbortSignal 深入解析与高级中止模式)
前端·ui·html·音视频·视频编解码
im_AMBER15 小时前
Browser Agent 开发:从浏览器插件到Electron CDP
前端·javascript·架构·electron·agent