我正在研究小型ASP.NET MVC项目,我得到了一个奇怪的行为。此时,项目与ASP.NET MVC默认模板的区别仅在于css样式表。身体标签完全是空的。在这里,您可以看到母版页:
<%@ Master Language="C#" Inherits="System.Web.Mvc.ViewMasterPage" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>
<asp:ContentPlaceHolder ID="TitleContent" runat="server" />
</title>
<link href="<%: ResolveUrl("~/Content/Site.css") %>" rel="stylesheet" type="text/css" />
<link href="<%: ResolveUrl("~/Content/ObscuraUI.css") %>" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="/Scripts/jquery-1.4.1.js" />
</head>
<body>
<div class="page">
<div id="header">
<div id="title">
<h1>Obscura.com</h1>
</div>
<div id="logindisplay">
<% Html.RenderPartial("LogOnUserControl"); %>
</div>
<div id="menucontainer">
<ul id="menu">
<li class="ui-corners-all" ><%: Html.ActionLink("Home", "Index", "Home")%></li>
<li class="ui-corners-all" ><%: Html.ActionLink("About", "About", "Home")%></li>
</ul>
</div>
</div>
<div id="main">
<asp:ContentPlaceHolder ID="MainContent" runat="server" />
<div id="footer">
</div>
</div>
</div>
</body>
</html>
和家庭控制器索引视图:
<%@ Page Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage" %>
<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
Home Page
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<h2><%: ViewData["Message"] %></h2>
<p>
To learn more about ASP.NET MVC visit <a href="http://asp.net/mvc" title="ASP.NET MVC Website">http://asp.net/mvc</a>.
</p>
<img src="../../Content/Images/Design/blackpony1440.jpg" alt="" class="protectedContent" />
</asp:Content>
我用firebug查看了生成的html - 头部被正确渲染,但是body标签是完全空的但是查看初始源显示正确的html。我试图在索引视图中抛出异常,我得到了错误页面。在构建项目时,我没有任何有用的警告。但是当我评论这一行时
<script type="text/javascript" src="/Scripts/jquery-1.4.1.js" />
一切都很好。
我想到了一些脚本失败,但如果我只导入一个空文件,我会得到空屏幕。为什么这样做?
感谢。
答案 0 :(得分:8)
您不应对<tag/>
标记使用自动结束标记(<script>
)。正如你所观察到的那样,这样做会让疯狂的事情发生。你需要改用它:
<script type="text/javascript" src="/Scripts/jquery-1.4.1.js"></script>