js实现iframe框架的面包屑功能

简介: js实现iframe框架的面包屑功能

js实现iframe框架的面包屑功能

什么是iframe框架

iFrame全称Inline Frame是HTML中的一个标签,用于在一个HTML文档中嵌入另一个HTML文档。iFrame框架可以将一个HTML文档嵌入到另一个HTML文档中的一个独立的窗口中,这个窗口可以独立于主窗口进行加载和渲染。iFrame框架可以用于以下场景:

  1. 在一个页面中嵌入另一个页面,例如在一篇文章中嵌入一段视频。
  2. 在一个页面中嵌入一个广告,可以独立加载和渲染,不影响主页面的性能。
  3. 在一个页面中嵌入一个登录框,可以通过iFrame框架实现跨域登录。

iFrame框架可以通过设置iFrame标签的属性来实现不同的效果,例如设置iFrame的宽度和高度、设置iFrame的边框、设置iFrame的src属性来指定要嵌入的HTML文档等。但是需要注意的是,由于iFrame框架可以跨域加载其他网站的内容,所以在使用iFrame框架时需要注意安全问题。


另外iframe解决了一个问题。

你比如说:一个项目你要写30个页面,需要来回跳转,而且每个页面的菜单栏都是一样的。简单来说就是30个页面有公共的html代码,css代码,js代码。你可以选择每个页面都复制粘贴一份,但是这样不会太过麻烦吗?

iframe就可以解决这个问题。这种情况情况下,30个页面公共部分的布局样式只需要写一遍即可,把这个作为iframe的框架。30个页面中不同的部分分别写不同的html文件,css样式,js代码。引入到这个框架中,就可以实现我们的预期目标。


如果有相同js,css,只需要放入一个公共的public.css / public.js,将公共文件路径引入html文件即可,但是公共的html应该怎么办呢?

这个时候iframe就显得很珍贵了,因为它实现了代码的重用。

想成为一个高手,就要具备重用代码的能力。用同一个函数能办类似的事情,用同样的代码能最大程度的做更多的事,这就算是高手。

什么是面包屑


面包屑(Breadcrumbs)是网站或应用程序中的一种导航方式,通过显示用户当前所处页面的路径来帮助用户快速定位到自己所需的内容或页面。
通常面包屑以一种层级结构的形式展现,每一层级代表一个页面或分类,用户可以通过点击面包屑上的链接回到之前的页面或分类。

你比如说,一个面包屑可能是这样的:

首页 > 电视 > 智能电视 > 55英寸智能电视,这表示用户当前正在查看的是55英寸智能电视的页面,并告诉用户如何回到电视或首页。


面包屑的作用在于:


提供导航:面包屑可以告诉用户当前所处位置以及如何返回到之前的页面或分类,方便用户进行导航。

提高用户体验:面包屑可以让用户更快速地找到自己需要的内容,提高用户的访问体验。

提高网站可用性:面包屑可以让用户更好地理解网站的结构和组织,提高网站的可用性和易用性。

需要注意的是,面包屑应该尽可能简洁明了,不应该包含太多的层级,以免影响用户体验。同时,面包屑应该与网站的其他导航方式相结合,提供更全面的导航。


太常见了,举几个例子:


面包屑的js实现

思路

在 iframe 框架中,实现面包屑导航通常是由父窗口来维护和显示的。

我们主要以以下思路为主开发:


在父窗口中,定义一个数组来存储当前页面的路径信息,例如:var breadcrumb = ['首页', '分类', '电视'];

在父窗口中,为 iframe 的 onload 事件添加一个监听函数,用于在 iframe加载完成后更新面包屑导航。例如:iframe.onload = updateBreadcrumb;

在 updateBreadcrumb 函数中,获取 iframe 中当前页面的路径信息,例如:var path = iframe.contentWindow.location.pathname;

将当前页面的路径信息添加到面包屑导航数组中,例如:breadcrumb.push(path);

更新面包屑导航的显示内容。可以通过 jQuery 来操作 DOM 元素,将面包屑导航数组中的内容渲染到页面中。

当用户点击面包屑导航中的某个链接时,可以通过 JavaScript 来控制 iframe 的 src 属性,使其加载对应的页面。

在每个页面中,可以通过 JavaScript 向父窗口发送消息,告知父窗口当前页面的路径信息,以便更新面包屑导航。

总体来说,iframe 框架的面包屑导航流程与普通页面的面包屑导航类似,只是需要在父窗口中来维护和显示面包屑导航,而在子窗口中则需要向父窗口发送消息来更新面包屑导航。

代码实现

html

<div id="breadcrumb"></div>
<iframe id="myFrame" src="index.html"></iframe>

js

var breadcrumb = ['首页']; // 初始化面包屑导航数组
var breadcrumbEl = document.getElementById('breadcrumb'); // 获取面包屑导航的 DOM 元素
var myFrame = document.getElementById('myFrame'); // 获取 iframe 的 DOM 元素
// 监听 iframe 的 onload 事件,更新面包屑导航
myFrame.onload = function() {
  var path = myFrame.contentWindow.location.pathname; // 获取 iframe 中当前页面的路径信息
  breadcrumb.push(path); // 将当前页面的路径信息添加到面包屑导航数组中
  renderBreadcrumb(); // 更新面包屑导航的显示内容
};
// 渲染面包屑导航的显示内容
function renderBreadcrumb() {
  var html = '';
  for (var i = 0; i < breadcrumb.length; i++) {
    if (i === breadcrumb.length - 1) {
      html += '<span>' + breadcrumb[i] + '</span>'; // 最后一个元素不加链接
    } else {
      html += '<a href="#" οnclick="goToPage(' + i + ')">' + breadcrumb[i] + '</a> <span>/</span> ';
    }
  }
  breadcrumbEl.innerHTML = html;
}
// 点击面包屑导航中的链接时,切换到对应的页面
function goToPage(index) {
  breadcrumb = breadcrumb.slice(0, index + 1); // 截取面包屑导航数组,保留前 index + 1 个元素
  var path = breadcrumb[index];
  myFrame.src = path; // 切换 iframe 的 src 属性
}

小结

我们首先要定义了一个数组 breadcrumb 来存储当前页面的路径信息,然后通过 myFrame.onload 事件来监听 iframe 加载完成后的事件,并在事件处理函数中更新面包屑导航数组,并调用 renderBreadcrumb 函数来更新面包屑导航的显示内容。

在 renderBreadcrumb 函数中,我们通过遍历面包屑导航数组来生成对应的 HTML 代码,并将其渲染到页面中的 breadcrumbEl 元素中。

最后,我们定义了一个 goToPage 函数,用于响应面包屑导航中的链接点击事件。在该函数中,我们通过截取面包屑导航数组来保留前面的元素,并更新 iframe 的 src 属性,以切换到对应的页面。


相关文章
|
9天前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
103 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
16天前
|
JavaScript 容器
带方向感知功能的js图片遮罩层插件
带方向感知功能的js图片遮罩层插件
|
2月前
|
JavaScript 前端开发 容器
jQuery多功能滑块插件r-slider.js
r-slider.js是一款jQuery多功能滑块插件。使用该插件,可以制作出滑块、开关按钮、进度条、向导步骤等多种效果。
43 5
|
2月前
|
缓存 监控 JavaScript
Vue.js 框架下的性能优化策略与实践
Vue.js 框架下的性能优化策略与实践
|
2月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
44 2
|
2月前
|
缓存 负载均衡 JavaScript
构建高效后端服务:Node.js与Express框架实践
在数字化时代的浪潮中,后端服务的重要性不言而喻。本文将通过深入浅出的方式介绍如何利用Node.js及其强大的Express框架来搭建一个高效的后端服务。我们将从零开始,逐步深入,不仅涉及基础的代码编写,更会探讨如何优化性能和处理高并发场景。无论你是后端新手还是希望提高现有技能的开发者,这篇文章都将为你提供宝贵的知识和启示。
|
2月前
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
36 1
JavaScript中的原型 保姆级文章一文搞懂
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
116 2
|
2月前
JS+CSS3文章内容背景黑白切换源码
JS+CSS3文章内容背景黑白切换源码是一款基于JS+CSS3制作的简单网页文章文字内容背景颜色黑白切换效果。
23 0
|
6月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
162 4