- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我继承了一个遗留代码库/网站,http://ninjawars.net 。在我开始在网站上编码之前,iframe 就已就位。
我经常听说 iframe 的问题(安全性、可访问性、布局问题),并且我非常确定 iframe 对搜索引擎不友好(这是一个很大的缺点)。我个人使用 iframe 的经验主要是加载时间问题(我猜是大量的 http 请求?)。
不幸的是,没有人说“摆脱 iframe”也为我的情况提供了有效的解决方案,通常假设简单地包含框架内容将使一切变得彩虹和 unicorn (例如 Converting from iframes )。就我而言,静态包含解决方案对我来说几乎没有任何作用。
jQuery load()(例如,将内容动态加载到 div 中)更适合,但转换到该方法需要时间,并且不利于搜索引擎或非 javascript 浏览的可访问性用户。 jQuery load() 解决了速度问题,但我不确定它是否解决了可访问性问题。即使没有 javascript,iframe 仍然可以工作(用于手动点击),尽管让 iframe 在 javascript 下工作的额外支持工作是否实用,我不确定。
最佳答案
iframe 并不是某些无名恶魔的产物,有些人会让您相信这一点。对于网络应用程序来说,它们仍然有非常有用的地方。
但是,它们绝对不利于搜索引擎优化!除非绝对必要,否则我绝不会建议“普通”公共(public)网站使用它们,尤其是在 SEO 是一个大问题的情况下。
我认为 jQuery 是解决可访问性问题的一个不错的选择。 jQuery 的一大优点是,对于那些没有 javascript 之类的搜索引擎的用户来说,可以轻松地使您的网站优雅地降级。
基本上,我使用 jQuery 访问新公共(public)网站的方式如下:
构建具有静态导航的网站。我通常从某个 ajax 请求(在您的情况下,在 iframe 中)获取的所有内容 block ,我都可以在其自己的页面中访问。 “联系我们”表单就是一个很好的例子 - 对于非 javascript 用户,将其放在自己的页面中,但最终会使用 ajax 将其加载到普通用户的模态 div 中。静态导航确保搜索引擎看到一切。在您的情况下,将 iframe 替换为仅包含指向 iframe 当前正在加载的页面的链接的 div。
添加 jQuery。一次一页,开始用 ajax 调用替换所有出现的静态导航链接,以加载您想要的内容。
不断重构 JavaScript,直到将其缩小为可在网站上的所有导航中运行的脚本。
一个简单的可正常降级的网站示例如下(取 self 工作过的网站):
$(document).ready(function() {
$("#menu a[href]").each(function() {
this.href = this.href.replace(/Index/, "Ajax");
})
.click(function() {
$.get(this.href, null, function(data) {
var $main = $("#main");
$main.hide();
$("#main").html(data);
$main.fadeIn("slow");
});
return false;
});
此脚本在网站上的所有页面中运行,将菜单导航目标 URL 中出现的任何“/Index/”替换为“/Ajax/”,这会将 URL 重定向到返回 ajax 响应的资源,然后添加处理将内容添加到页面的单击处理程序。
现在搜索引擎和非 JS 用户可以遵循静态导航,JS 用户可以获得更快捷的 UI 和一些效果。
关于jquery - 旧版 iframe,什么是它们的完整替代品?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1911513/
具体详细介绍请看下文: 在使用文件进行交互数据的应用来说,使用FTP服务器是一个很好的选择。本文使用Apache Jakarta Commons Net(commons-net-3.3.jar)
我在日志文件中收到这些警告: WARN 2013-01-15 00:08:15,550 org.eclipse.jetty.http.HttpParser- HttpParser Full for
我在使用特定网页时遇到问题。当我按下链接时,我收到应用程序错误(不是 http 错误等,而是应用程序级别错误)。 但是我打开了开发人员工具和网络控制台,我看到没有请求发送到服务器。 所以我双击并选择查
我没有组装经验,但这是我一直在做的。如果在通过程序集中的指针传递参数和调用函数时缺少任何基本方面,我希望输入。 例如,我想知道是否应该还原ecx,edx,esi,edi,。我读到它们是通用寄存器,但我
我没有组装经验,但这是我一直在做的。如果在通过程序集中的指针传递参数和调用函数时缺少任何基本方面,我希望输入。 例如,我想知道是否应该还原ecx,edx,esi,edi,。我读到它们是通用寄存器,但我
我正在尝试创建完整 uiscrollview 的快照,所有内容大小,我已经搜索了很多,并且我在 SO 上找到了一些东西,如下所示: Getting a screenshot of a UIScroll
我想复制一个包含以下结构的Vector,对我来说重要的是在修改复制的 vector 时保持原始Vector完整: public class objet_poid_n { public int
给定一个示例字符串 s = '嗨,我的名字是 Humpty-Dumpty,来自“爱丽丝,爱丽丝镜中奇遇记”',我想将其分成以下 block : # To Do: something like {l =
已关闭。此问题旨在寻求有关书籍、工具、软件库等的建议。不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以
我正在尝试创建一个正则表达式来查找文本中的 Linux 文件路径,但是正则表达式对我来说非常陌生。我有下面的代码片段,它将识别下面文件结构的开头。 .*(/bin/|/home/).* 完成正则表达式
我正在寻找远程托管的 JPG 的尺寸、宽度和高度。我已经了解了如何通过下载完整图像来执行此操作。 但是,如果我可以通过仅下载足以获取此信息的方式来做到这一点,那将是理想的。 典型的图像大小为 200K
有没有办法让下面的代码: import traceback def log(message): print "%s: %s" %(traceback.extract_stack()[0:-1]
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 3 年前。 Improve this qu
git show 显示了修订版中所做的所有更改。但是,它会打印出所有更改——而不仅仅是文件名。 git show --stat 只显示文件名,但它把它们截断了!有没有办法获得已更改文件名的完整列表?
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
当我在模板中调用我的模型 get_absolute_url 方法时,我想要一个绝对/完整的 url。在我的入门模型中,我有以下内容: def get_absolute_url(self): r
我正在使用 jQuery 1.5.1 这是我的代码: $('.cellcontent').animate({ left: '-=190'}, { easing: alert('start
我正在使用下面的方法删除条形图并使用新数据更新条形图,但这样做时出现了一个小故障/完整的图表消失 1 秒,直到加载新数据。但是是否可以通过仅增加/减少柱形而不实际消失图表来实现相同的目的。 d3.se
基于 this question 中的讨论,任何人都可以提供代码或代码链接,显示 NumericLiteralX 模块的完整实现(例如 this one )?我对 NumericLiteralX 模块
我的目标是检索网站的 html,并将其转换为可读的String。我下面的代码可以工作,但我遇到了一个技术问题:当我尝试检索 http://time.gov/HTML5 的 html 时,我在 andr
我是一名优秀的程序员,十分优秀!