- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在将大型 WebForms 应用程序转移到 MVC。
在 WebForms 应用程序中,我们有一些可重用的控件 (.ascx
)。例如,一个在您键入时显示用户名建议的文本框。该控件向页面添加了一些 JS/CSS,具有一些服务器端逻辑和自定义属性(如 SelectedUserID
)。
在 MVC 应用程序中它应该是什么?我如何将这些东西封装到 MVC 应用程序中的一个可重用实体中?也许是局部 View ?但是您不能将 JS/CSS 添加到页面的 <head>
。从局部 View (最好检查它是否尚未添加)...另外,我如何返回类似提到的 SelectedUserID
的内容在局部 View 中?
重新表述问题 - 您将如何在 MVC 应用中实现这样的控件?
附言。我知道您仍然可以在 MVC 应用程序中使用 .ascx 用户控件,但这似乎是一种“hacky/legacy”方式。什么是“合法”选项?
最佳答案
你的问题很宽泛。我所有的评论/答案都将在 Razor 中.在我看来,如果你打算切换到 MVC,你还不如使用 Razor。转换的理由有很多,但对于任何正在迁移的人,我会说我的首选,最好的理由有两个; first razor 让我放弃了一些关于如何使用 webforms 进行编程的坏习惯,并且在同一个庄园中它迫使我重新编写我的代码,而不是试图复制、粘贴和更改原始代码以在 MVC 中工作。
The control adds some JS/CSS to the page, has some server-side logic and custom properties. What should it be in an MVC app?
这是一个漂亮的religious software问题。有很多方法可以做到这一点。
所以我对如何在 MVC 中添加 JS/CSS 的宗教观点。包含服务器端的一种方法是在 Layout/Master 模板中创建一个区域。
Views/_ViewStart.cshtml
@{
Layout = "~/Views/Shared/Layout.cshtml";
}
Views/Shared/Layout.cshtml
<!doctype html>
<head>
<link href="/Styles/Global.css" rel="stylesheet" type="text/css" />
@RenderSection("Styles", required: false)
<script src="/Scripts/Global.js" type="text/javascript"></script>
@RenderSection("Scritps", required: false)
这将允许每个 View 选择(因为 required=false
)使用 RenderSecion 代码添加任何样式或脚本。
Views/Home/Index.cshtml
@section Styles {
<link href="/Styles/Home/Index.css" rel="stylesheet" type="text/css" />
}
这非常简单,对于许多简单到中等复杂的网站来说可能是一个很好的解决方案。这对我来说还不够,因为我需要按照您的要求进行操作,并且只包含真正需要的文件。此外,部分 View 和模板无法呈现部分,我发现这是一个巨大的 PITA。所以我添加了一些 HtmlHelper 扩展方法。 (我只打算展示 Javascript 的代码,因为样式表几乎是相同的代码。这些方法不允许重复的 url。
域/HtmlHelperExtensions.cshtml
public static class HtmlHelperExtensions
{
private const string _JSViewDataName = "RenderJavaScript";
private const string _StyleViewDataName = "RenderStyle";
public static void AddJavaScript(this HtmlHelper HtmlHelper, string ScriptURL)
{
List<string> scriptList = HtmlHelper.ViewContext.HttpContext.Items[HtmlHelperExtensions._JSViewDataName] as List<string>;
if (scriptList != null)
{
if (!scriptList.Contains(ScriptURL))
{
scriptList.Add(ScriptURL);
}
}
else
{
scriptList = new List<string>();
scriptList.Add(ScriptURL);
HtmlHelper.ViewContext.HttpContext.Items.Add(HtmlHelperExtensions._JSViewDataName, scriptList);
}
}
public static MvcHtmlString RenderJavaScripts(this HtmlHelper HtmlHelper)
{
StringBuilder result = new StringBuilder();
List<string> scriptList = HtmlHelper.ViewContext.HttpContext.Items[HtmlHelperExtensions._JSViewDataName] as List<string>;
if (scriptList != null)
{
foreach (string script in scriptList)
{
result.AppendLine(string.Format("<script type=\"text/javascript\" src=\"{0}\"></script>", script));
}
}
return MvcHtmlString.Create(result.ToString());
}
}
更新的 Views/Shared/Layout.cshtml
<!doctype html>
<head>
<link href="/Styles/Global.css" rel="stylesheet" type="text/css" />
@Html.RenderStyleSheets()
<script src="/Scripts/Global.js" type="text/javascript"></script>
@Html.RenderJavascripts()
更新 View /Home/Index.cshtml
@Html.AddStyleSheet("/Styles/Home/Index.css")
关于你的下一个问题......
How do I encapsulate those things into one reusable entity in an MVC app? Maybe a partial view?
Razor 支持分部 View 和模板。虽然从技术上讲,两者的功能有很大的重叠,但为了让程序员在需要时利用它们,它们的设计方式存在局限性。
部分 View 不需要模型/类才能呈现。这是一个完全有效的局部 View :
/Views/Home/Index.cshtml
@Html.Partial("Partial-Menu")
/Views/Shared/Partial-Menu.cshtml
<div id="menu">
<a href="/">Home</a>
<a href="/Home/About">About Us</a>
</div>
另一方面,模板确实需要模型才能呈现。这是因为模板是一种将任何类或结构呈现为编辑模板或显示模板的方法。
/Models/Person.cs
public class Person
{
public string FirstName { get; set; }
public string LastName { get; set; }
}
/Controllers/HomeController.cs
public ActionResult Index()
{
Person model = new Person();
model.FirstName = "Jon";
model.LastName = "Doe";
return this.View(model);
}
/Views/Home/Index.cshtml
@model Project1.Models.Person
@Html.DisplayModel()
@Html.EditforModel()
/Views/Shared/DisplayTemplates/Person.cshtml
@model Project1.Models.Person
<div>@Html.LabelFor(x => x.FirstName) @Html.DisplayFor(x => x.FirstName)</div>
<div>@Html.LabelFor(x => x.LastName) @Html.DisplayFor(x => x.LastName)</div>
/Views/Shared/EditorTemplates/Person.cshtml
@model Project1.Models.Person
<div>@Html.LabelFor(x => x.FirstName) @Html.EditorFor(x => x.FirstName)</div>
<div>@Html.LabelFor(x => x.LastName) @Html.EditrorFor(x => x.LastName)</div>
在我看来,任何可能变成用于数据输入的表单的模型都应该是模板。这是我更喜欢封装我的模型的方式。使用前面提供的扩展方法,我的部分 View 和模板都可以根据需要加载包含内容(目前只有我的大量模型之一实际需要使用它)。
我的偏好是每个呈现的页面最多包含三个(每个 Javascript 和样式)。我基本上有一个 Global.css/js、一个 Controller Home.css/js 和一个可能包含的页面 Index.css/js。我很少有 Controller 。
关于asp.net-mvc - 用户控件的 MVC 替代品,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10823583/
我想实现自定义搜索,但遇到了一个麻烦。我需要将 UIButton、SearchBar 组合在一个控件中,以便我可以通过指针引用它。然后我将向该组合控件动态添加更多 UIbutton。最重要的是,我想将
它没有在我的方法中执行 if block 中的语句 母版页:- 页面加载事件:- Control c = new Control(); DoSomething(c); 我的方法:- protecte
ComboBox 控件有一个 setConverter 方法,请参阅 JavaFX ComboBox - Display text but return ID on selection举个例子。我正在
我没有找到任何包含用于标记化(标记)文本输入的控件的 wpf 库。也许我找不到库,因为我错误地调用了这个组件。怎么叫或者哪里有这样的库? 最佳答案 DevExpress WPF 库包含多个数据编辑控件
是否有 Silverlight 控件允许您输入文本并将其突出显示为代码? 例如: foreach (client in Clients){ client.Save();} would become
我有以下用户控件 a) Panel.ZIndex="99999999" 是否是将此控件设置为该控件中 TopMost 的正
是否可以在 Windows 窗体中使用 C# 在窗体加载时隐藏所有特定控件,例如标签或按钮,然后选择显示我不想显示的那些? 我有一个包含很多按钮和标签的程序,但我只想在加载时显示一两个,我觉得对每个标
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: Duplicating components at Run-Time 我有一个TMyControl ( Contro
我正在尝试在 Delphi 中编写一个 dll 库,其中包含一个创建 TFrame 后代实例并返回它的函数。但是当我在应用程序中导入这个函数时,每次调用它时,我都会得到一个异常,例如“'xxx'控件没
是否有 Win32 API 调用来确定哪些窗口和/或控件在特定坐标和/或鼠标下可见? 最佳答案 您可以使用GetWindowFromPoint 。它将返回窗口句柄,以便您可以使用 GetClassNa
我需要在编辑控件中输入以下公式: 公式是在 MS Word 中制作的。尝试将其复制/粘贴到编辑控件(单行或多行)后,我得到 M 0.33 Q10T9.1-9.7。 当我输入这个时,我正在研究 Rich
我只是想成功地将它添加到我的窗口中,但这却出奇地困难。 我已经尝试过 #include "windef.h" #include "winbase.h" #include "initguid.h" #i
我希望能够使用 google maps api v3 拥有自己的“街景”按钮。单击按钮时,我希望它根据我的标记经纬度加载街景。然后我希望按钮更改为“返回 map ”,然后再次加载默认 map View
我目前正在用 PHP 开发(另一个)开源 CMS,我想使用 javascript 控件,尤其是管理面板。问题是,是否有任何具有 PHP 接口(interface)的开源、可自由分发的控件(用于创建 j
我为其编写软件的产品之一是会计类应用程序。它用 C++ 编写,使用 C++ Builder 和 VCL 控件,连接到运行在 Linux 上的 PostgreSQL 数据库。 PostgreSQL 数据
我使用 Key Listener 来读取用户的输入,但我遇到了问题。首先,我读到 JTextField“请输入您的姓名”。如果用户输入一个名字,例如 John,它将更改为 John。但是,如果用户输入
我正在尝试对齐数据表列中的复选框(h=center,v=middle) ... 但复选框仍然显示在错误的位置(见附图)
我有一个包含统计信息的 JSON 数据树: { prefix: "a", count: 20, children: [ { prefix: "a:b", c
我在 Photoshop 中设计了一个模型,我打算将它应用到我的产品目录的 ListView 控件中,但它似乎没有正确显示(未对齐?),我希望这里的人可以像我一样指出我的错误试图弄清楚无济于事。 预期
您是使用 ASP.NET 控件还是仅使用带有 CSS 的 HTML? 我在 TextBox 和 DropDownList 的宽度方面遇到了一些问题。在不同的浏览器中,宽度会有所不同,控件的大小也不会相
我是一名优秀的程序员,十分优秀!