前端iframe标签介绍及使用

一、使用的场景:有重复的板块内容显示的时候

后端如果是模板渲染方式(得到页面是通过继承的形式),可以换成iframe来请求直接获取子功能页面

iframe标签的作用:iframe标签可以实现html主页面嵌套html子页面,子页面可以是一个功能页面,在某些时候使用iframe非常的方便。所以如果是模板渲染方式的,前端就可以使用iframe标签节省一点网络带宽(传输的内容会少一些,并且主页面不会刷新,只是iframe在请求得到新的资源)。

二、模板渲染和iframe的对比:

1.子页面通过继承的方式去实现,并且实现了html页面功能的拆分:

不好的地方:通过继承,表示渲染模板时候,会先去加载继承的页面,再加载子页面,这样模板页面也会在网络传输,这样会占一些无用的带宽。使用iframe后:页面通过模板渲染,也仅是某个功能页面,返回的时候,会少返回模板继承的部分。

2.菜单点击效果(主页面可能有多个菜单),要在后端提前去渲染好用户点的哪个菜单,才能返回给用户新的页面。不好的地方:增加了后端编码的复杂度,需要通过if判断把点击效果也加在标签上面,这样后端又会吃一些cpu的资源。使用iframe后:由于前端只是发送src请求(仅改变子页面内容),主页面不会改变,所以菜单只需写好前端事件即可,这样就会少后端很多模板渲染的麻烦事,可以少渲染一些内容,效率也会提升一点。

三、模板渲染比iframe这种方式好的地方:

iframe是一个url显示的所有功能页面,模板渲染可以通过不同的url,来得到不同前端信息界面,而iframe这种方式能看见的url只有首页的url,所以用iframe的话,一般只会一个url去操作,如果要获取某个功能页面,首次打开也只能通过鼠标点击,才能请求到那个功能页面,但是效率来说肯定是iframe方式会高一点

1.iframe标签的使用:

注:

(1) 下面都是使用的jquery的写法定位的标签,和原生js查找不同

(2) 它俩之间的转换

  jquery >>> dom  === $('iframe')[0]  : 关键是这个[0]

  dom >>> jquery  === $(dom定位到的标签)

格式:

属性:src  # 获取html页面的url网址 frameborder  # 表示是否显示框架的边框,1显示,0不显示

2.iframe通过点击事件获取页面的写法

下面是点击搜索按钮的事件

前端iframe标签介绍及使用_第1张图片

# 这个是在iframe标签中场景,window.parent切换到父窗口

# 如果是在iframe外直接$('iframe').attr('src', new_url)即可

3.iframe的刷新页面及回退写法

# 先要找到iframe标签,在执行bom操作即可

(1) 在iframe标签中实现刷新

$(window.parent.document).find('iframe')[0].contentWindow.location.reload(true);

(2) 在iframe标签中实现回退

$(window.parent.document).find('iframe')[0].contentWindow.history.back();

(3) 主窗口的写法

$('iframe')[0].contentWindow.location.reload(true);

$('iframe')[0].contentWindow.history.back();

4.获取iframe的当前url

注:如果在iframe中切换了子页面的url,通过src只会取到第一次的给的src属性

$(window.parent.document).find('iframe')[0].contentWindow.location.href;

5.主页面和iframe子页面互相调用函数

使用场景:

(1) 模态框的弹出,不能说你模态通过子页面的点击,仅在子页面有模态框的效果

(2) 各种消息弹框的显示,不能说在子页面显示,会错位

6.1在iframe中调用主页面的内容

window.parent.要调用的函数();

例子写法:

# 父页面中

前端iframe标签介绍及使用_第2张图片

前端iframe标签介绍及使用_第3张图片

# iframe中

前端iframe标签介绍及使用_第4张图片

 # iframe中调用上级窗口的函数写法

6.2.调用iframe的函数写法

$('iframe')[0].contentWindow.要调用的函数();

你可能感兴趣的:(Vue,html,jquery,html5)