gpt4 book ai didi

c# 扩展方法和属性

转载 作者:太空宇宙 更新时间:2023-11-03 12:12:25 25 4
gpt4 key购买 nike

我正在为我的 Web 应用程序使用 C# 和 MVC,我希望在编码时让我的生活变得轻松,所以我做了以下操作以在我的 View 中使用。我用的是Devexpress。因此,为了减少我在 View 中的编码,我执行了以下操作。

我创建了这样一个类:

public class EditorUtils
{
public static void Label(HtmlHelper htmlHelper, string CssClass, Object Model, String DataField)
{
LabelSettings lbSettings = new LabelSettings
{
Text = Text,
Width = Width
};
lbSettings.ControlStyle.CssClass = CssClass;
htmlHelper.DevExpress().Label(lbSettings).Bind(DataBinder.Eval(Model, DataField)).GetHtml();
}
}

这对我来说非常容易,因为我现在只有一行代码来在 View 中呈现标签。

我是这样使用的:

EditorUtils.Label(Html, "MyCssClass", Model, "FieldName1");
EditorUtils.Label(Html, "MyCssClass", Model, "FieldName2");

我喜欢通过将它们放在一个 html 表中来组织我的编辑器,并且我创建了一个这样的类:

public class HtmlUtils
{
public static void BeginTable(HtmlHelper htmlHelper)
{
htmlHelper.ViewContext.Writer.Write("<table>");
}

public static void NewRow(HtmlHelper htmlHelper)
{
htmlHelper.ViewContext.Writer.Write("<tr><td>");
}

public static void NewColumn(HtmlHelper htmlHelper, string CssClass)
{
htmlHelper.ViewContext.Writer.Write(string.Format("</td><td class=\"{0}\">", CssClass));
}

public static void EndRow(HtmlHelper htmlHelper)
{
htmlHelper.ViewContext.Writer.Write("</td></tr>");
}

public static void EndTable(HtmlHelper htmlHelper)
{
htmlHelper.ViewContext.Writer.Write("</table>");
}

}

在我看来,我是这样使用它的。

HtmlUtils.BeginTable(Html);
HtmlUtils.NewRow(Html);
EditorUtils.Label(Html, "MyCssClass", Model, "FieldName1");
HtmlUtils.NewColumn(Html);
EditorUtils.Label(Html, "MyCssClass", Model, "FieldName2");
HtmlUtils.EndRow(Html);
HtmlUtils.EndTable(Html);

这将生成一个包含 1 行 2 列值的表格。

现在进入正题。我想通过做这样的事情进一步优化它。

HtmlUtils.BeginTable(Html);

EditorUtils.Label(Html, "MyCssClass", Model, "FieldName1").NewRow(Html); //this will create a new row and column and put the lable inside the field
EditorUtils.Label(Html, "MyCssClass", Model, "FieldName2").NewColumn(Html); //this will create a new column and put the lableiside the field

HtmlUtils.EndTable(Html);

我非常努力地寻找解决方案,但迄今为止找不到。有人可以把我送到正确的方向吗。

亲切的问候,

最佳答案

我刚刚在没有测试能力的情况下很快写完了这个。我希望它有所帮助,因为我主要使用 Web 表单而不是 mvc。

它也可能与查看以下页面有关。 (自从我使用这些以来已经有一段时间了,但我怀疑它们比使用硬编码字符串更好..) HtmlGenericControl Class Table Class

public static class HtmlUtilsExtensions
{
public static HtmlHelper BeginTable(this HtmlHelper htmlHelper)
{
return htmlHelper.ViewContext.Writer.Write("<table>");
}

public static HtmlHelper NewRow(HtmlHelper htmlHelper)
{
return htmlHelper.ViewContext.Writer.Write("<tr><td>");
}

public static HtmlHelper NewColumn(HtmlHelper htmlHelper, string CssClass)
{
return htmlHelper.ViewContext.Writer.Write(string.Format("</td><td class=\"{0}\">", CssClass));
}

public static HtmlHelper EndRow(HtmlHelper htmlHelper)
{
return htmlHelper.ViewContext.Writer.Write("</td></tr>");
}

public static HtmlHelper EndTable(HtmlHelper htmlHelper)
{
return htmlHelper.ViewContext.Writer.Write("</table>");
}

然后你可以做这样的事情。

Html
.BeginTable()
.NewRow()
.Label(Html, "MyCssClass", Model, "FieldName1")
.NewColumn()
.Label(Html, "MyCssClass", Model, "FieldName2")
.EndRow()
.EndTable();


Html.BeginTable().NewRow()
.Label(Html, "MyCssClass", Model, "FieldName1")
.NewColumn()
.Label(Html, "MyCssClass", Model, "FieldName2")
.EndRow().EndTable();

请务必让我们知道您的进展情况 :D

关于c# 扩展方法和属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51461955/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com