在我的 Web 应用程序中,我得到了包含默认 header 内容的 Header.jsp 文件。我将它包含在所有其他页面中,使用 jsp:include 标记在每个单独页面的 body 标记内。
Header.jsp 包含自己的 HEAD 标记,用于指定默认元标记、链接样式表、脚本和一些 HTML 元素。同时,我将在所有其他单独页面中使用另一组 HEAD 标记来定义标题、页面特定脚本和样式表。
例如:
Header.jsp
<head>
<link rel="shortcut icon" href="<%=request.getContextPath()%>/images/favicon.ico" type="image/x-icon" />
<meta http-equiv="X-UA-Compatible" content="IE=edge"/>
<script src="js/jquery.js"></script>
<link rel=stylesheet type="text/css" href="dashboard.css" >
</head>
<h2>Dashboard</h2>
主.jsp
<!DOCTYPE html>
<html>
<head>
<title>Main page</title>
<script src="main.js"></script>
</head>
<body>
<jsp:include page="Header.jsp" flush="true" />
.....
other HTML contents specific to main page
.....
</body>
</html>
这样做是否有效?
最佳答案
这不是一个好的解决方案,但绝对有效。
人们通常会在理论上回答这些问题,比如“不,因为按照标准它是无效的”。没错,它不是。 future 的浏览器可能不支持它,一些源代码解析器可能会感到困惑,检查你的投资组合的 HR/IT 专家可能认为你比 Jon Snow 知道的少,以及各种各样的坏事。 理论上。但它确实发生在现实世界中,浏览器并不愚蠢:它们知道你的意思,它们会接受两个 head 标签并按预期工作。它们知道你的意思。 p>
这不仅仅是偶然。
他们有很好的理由:
<强>1。 head 标签是可选的。 (请参阅文章下方的注释!)
浏览器接受类似 headtag 的内容,甚至 在它之外,因此实际上它们会忽略标签本身完全。如果他们忽略一个,他们可能也会忽略几个。
<强>2。访客是宝贵的。
浏览器希望您享受您的时间。他们想向您展示他们可以从他们所拥有的困惑中组成的最好的页面。 这是他们的意图,他们想向您展示互联网是有效的,而不是告诉您您最喜欢的网站有多糟糕。如果他们能够找出 html 代码想要表达的内容(并且结构中没有致命的歧义),他们将尽最大努力修复页面。
<强>3。错误的标记容忍度是一回事。
浏览器不仅有耐心和宽容,而且有时他们会做一些杂技 Action 来让你的东西正常工作。看看这个可怕的烂摊子:
<!-- no doctype! -->
<!-- no HTML tag! we're all gonna die! -->
<head>
<style>
body {background:#002233;}
</style>
</head>
<head><!-- let's twist again! -->
<style>
body {color:white}
</style>
<!-- we didn't even close the second one!! -->
See this text?<br>
With the background AND color properly set?<br>
<br>
Your browser's quite a badass.
关于浏览器容忍度,here's a lot more带有 super 丑陋的例子 - 确保你在回来时忘记你所看到的一切!)
所以是的,当然,原则是“成为您的浏览器的好 friend ”,无论它如何巧妙地修复您的错误。但是如果你在一个黑暗的地牢中醒来,周围有饥饿的狮子,而你唯一的出路就是使用两个
标签 - 好吧,不要犹豫!它不是损坏的语法,它不是严重违反 HTML5 规则 - 它只不过是一个方便的作弊工具。并且不要相信非标准、不整洁的网站会繁荣得多的普遍神话:人们通常只是不确定并希望保持安全。通常,他们将 hell 描述为验证器失败的网络作者所在的地方。
TLDR:在实践中,两个 head 标签起作用。
现在请尽可能只吃一个。
ADDITIONAL NOTES
正如@StanislavBerkov 所指出的,W3C 和 MDN 都建议 HEAD 标记是隐含的,这意味着最好完全保留 head 标记。如果您有只使用其中一个的标准选项,我不会推荐这种方法,但没有显然比有两个更好。有关该主题的文档不是很清楚,因此请确保您在主要浏览器中测试所有内容 - 但同样,在实践中,您不会遇到任何问题。
关于html - HTML可以包含两个HEAD标签吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24157836/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我试图使用yard记录一些Ruby代码,尽管我所做的正是所描述的here或here#@param[Integer]thenumberoftrials(>=0)#@param[Float]successprobabilityineachtrialdefinitialize(n,p)#initialize...end虽然我仍然得到这个奇怪的错误@paramtaghasunknownparametername:the@paramtaghasunknownparametername:success然后生成的html看起来很奇怪。我称yard为:$yarddoc-mmarkdown我做错了什么?
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择