C # 코드에서 HTML을 만드는 가장 좋은 방법은 무엇입니까? [닫은]


15

마크 업은 코드가 아닌 마크 업으로 유지되어야한다고 생각합니다.

코드 뒤에 HTML을 작성하는 것이 허용되는 상황에 도달했습니다. 모범 사례가 무엇인지 또는 어떻게해야하는지에 대해 의견을 나누고 싶습니다.

코드 뒤에 HTML을 작성하는 것이 언제 가능합니까? 이 HTML을 만드는 가장 좋은 방법은 무엇입니까? (예 : 문자열, StringBuilder, HTMLWriter 등)


이 HTML 마크 업을 뱉을 템플릿과 자리 표시자를 사용해보십시오.
Yusubov

5
다른 옵션 : 데이터 모델을 기반으로 XML을 생성 한 다음 XSLT를 사용하여 XML을 HTML로 변환하십시오.
FrustratedWithFormsDesigner

방금 HTML5 용 C # / XAML에 대해 오늘 알림을 받았으며 유망한 것으로 보이며 시나리오에 적합 할 수 있습니다. cshtml5.com
softveda

XSLT 경로의 문제점은 현지화에 있습니다. 두 개의 언어가 필요한 경우 두 개의 XSLT 스타일 시트가 필요하며이를 병렬로 유지하십시오. 지옥이야 C #에서 HTML을 텍스트 파일에 쓰는 것이 좋습니다. String.Format과 $ ".. {variable} ..."을 WPFLocalization과 함께 사용 하시겠습니까?
Erik

답변:


12

여기서 Razor 와 같은 것을 사용할 수 없습니까? 뷰 엔진을 사용하여 많은 HTML 생성을 수행하는 경우 훨씬 쉽게 만들 수 있기 때문입니다. 또한 ASP.NET 외부에서 사용되도록 제작되었습니다.

그러나 때때로 그것은 당신이 필요로하지 않는 것입니다. .net (mvc)의 일부인 TagBuilder 클래스 사용을 고려 했습니까 ? System.Web.UI 에는 HtmlWriter 도 있습니다 (웹 양식 용). 당신이 만드는 경우이 중 하나를 추천합니다 Controls또는 Html Helpers.


3
앱 면도기 내에서 템플릿을 사용해야하는 경우 +1이 좋습니다. 비 asp.net 앱에 면도기를 장착하기위한 훌륭한 옵션이 필요한 경우 razorengine @ nuget.org/packages/RazorEngine을 확인하십시오 .
Wyatt Barnett

1
클래스 라이브러리에서 html (로드)을 생성 해야하는 비슷한 요구 사항이 있습니다. 나는 이것을 위해 면도기를 사용하고 싶지만 dll에서 cshtml 파일을 유지하는 방법을 이해하려고 노력하고 있습니다. 함께 묶을 수 있습니까?
Yashvit

모든 문자열을 전달할 수 있습니다. stackoverflow.com/questions/3628895/…
Daniel Little

14

HTML Agility Pack 을 사용하여 HTML 을 어셈블 한 다음 텍스트 파일에 작성합니다.

Html Agility Pack을 강력하고 HTML 호환 HTML 친화적 으로 만들기 위해 많은 시간이 소요되었습니다 .

HTML을 생성하는 샘플 응용 프로그램도 포함되어 있다고 생각합니다.

홈페이지에서 :

샘플 애플리케이션 :

페이지 수정 또는 생성 원하는 방식으로 페이지를 수정하고, DOM을 수정하고, 노드를 추가하고, 노드를 복사하는 등의 방법으로 이름을 지정할 수 있습니다.


5

내가 사용하는 것이 htmltags을 HTML을 만들 수 있습니다.

예:

var tag = new HtmlTag("span")
    .Text("Hello & Goodbye")
    .AddClass("important")
    .Attr("title", "Greetings")

그런 다음 HTML을 구문 분석하려면 CSQuery

예:

dom.Select("div > span")
    .Eq(1)
    .Text("Change the text content of the 2nd span child of each div");

2

물론 이러한 노력을 지원할 수있는 HTML Agility Pack과 같은 라이브러리가 있습니다.

기존 라이브러리를 사용하고 싶지 않고 단순하고 까다로운 코드를 원한다면 이전 답변과 같은 동작을 추상화하는 아이디어가 마음에 듭니다. 또한 몇 가지 이유로 문자열이 아닌 기본 StringBuilder를 사용하는 아이디어가 마음에 듭니다.

  1. 문자열은 문자열 빌더보다 효율적이지 않습니다
  2. StringBuilder는 색인 가능한 데이터 구조입니다.

대규모 엔지니어링 HTML 엔진이 필요하지 않은 경우 간단하고 직관적 인 인터페이스를 작성합니다.

AddLineBreak();
AddSimpleTag(string tagName);
AddSimpleTagAt(string tagName, string content, int index);
Output();

1
인덱서 블 데이터 구조는 강력한,하지만 난 걱정하지 않을 너무 효율성에 대해 많은 : codinghorror.com/blog/2009/01/...
짐 G.

1
나는 현의 무거움, 특히 정말 큰 현에서 약간의 시간을 받았습니다. StringBuilder는 용량이 커질수록 메모리 효율성과 프로세서 효율성이 뛰어납니다. 따라서 HTML이 실제로 커질 수있는 이와 같은 구현에서는 StringBuilder로 시작합니다. HTML이 크게 커지지 않는다는 보장이 있다면 문자열이 충분할 것입니다.
Tim C

1
HTML이 정말 커질 수 있다면 HTML Agility Pack을 추천합니다. [실제로 2 분 전에 HTML 민첩성 팩을 권장했습니다. :)]
Jim G.

1

문자열 만 사용하면 출력 데이터에서 모든 HTML 예약 문자를 이스케이프 처리해야합니다.

&    &
>    >
<    &lt;
"    &quot;
'    &apos;

그래도 문자열을 직접 사용하는 대신 HTML 인식 클래스 또는 라이브러리를 사용하는 것이 좋습니다. HTMLWriter는 꽤 좋은 시작처럼 보입니다.


이 통찰에 감사드립니다. 이것이 읽을 수있는 사람이라면 이것이 아이템 템플릿에서 데이터 테이블의 값을 전달하는 데 사용하는 것입니다. 핵심은 Mike Clark이 제안한대로 HTML을 인식하는 것입니다. <asp : Button ID = "btnEdit"CssClass = "btnmaatwerksmall"runat = "server"Text = "Wijzig"OnClientClick = '<% # String.Format ( "OpenChildInEnterprise ( '{0}', '{1}', {2} '); ", Eval ("Cursus "), Eval ("Omschrijving "), Eval ("Opmerking ")) % > '/>
real_yggdrasil

-1

원래 게시물 이후 거의 2 년이 걸렸습니다. 여기에 저에게 잘 맞는 솔루션이 있습니다. 대상 문서에서 다음을 배치합니다.

<table>    
    <%:theHtmlTableMomToldYouAbout() %>    //# Where I want my rows of table data to go
</table>

호출되는 함수는 다음과 같습니다.

    public HtmlString theHtmlTableMomToldYouAbout()
    {
        string content = "";
        HtmlString theEnvelopePlease = null;

        for (int i = 0; i < 5; i++)
        {
            content = content + "<tr><td>The Number Is: " + i + "</td></tr>";
        }
        theEnvelopePlease = new HtmlString(content);
        return theEnvelopePlease;      
    }

그리고 브라우저의 결과 출력은 예상대로입니다 :
숫자 : 0
숫자 : 1
숫자 : 2
숫자 : 3
숫자 : 4

소스를 볼 때 다음을 발견합니다.

<table>
    <tr><td>The Number Is: 0</td></tr>
    <tr><td>The Number Is: 1</td></tr>
    <tr><td>The Number Is: 2</td></tr>
    <tr><td>The Number Is: 3</td></tr>
    <tr><td>The Number Is: 4</td></tr>
</table>

1
귀하의 솔루션에 '콘텐츠'가 불변의 문자열이되는 것과 같은 많은 문제 가이 질문에 대한 낮은 점수의 게시물에 설명되어 있음을 지적합니다.

-1

화염!

var html = "";
html += "<table class='colorful'>";
foreach(var item in collection) {
     html += "<tr>";
     html += "<td class='boldCell'>" + item.PropWhatever + "</td>";
     // more cells here as needed
     html += "</tr>";
}
html += "</table>";
placeholder1.InnerHtml = html;

나는 이것에 대해 하향식으로 조사 할 것이지만, .NET에 대해 정말로 많이 알기 전에 코드에서 HTML을 수정해야했던 전 디자이너로서 위의 코드는 HTML 생성을 추상화하는 방법보다 이해하기가 훨씬 쉽습니다. 디자이너가 HTML을 수정해야 할 수도 있다고 생각되면 다음과 같은 간단한 문자열을 사용하십시오.

코드로 HTML을 작성할 때 많은 개발자가 놓친 부분은 HTML에서 속성에 작은 따옴표 나 큰 따옴표가 허용된다는 것입니다. 따라서 코드에서 모든 인용 부호를 이스케이프 처리하는 대신 (시작되지 않은 사람에게는 지옥처럼 보이지 않음) 문자열 안의 HTML 인용 부호에 작은 따옴표를 사용하십시오.


좋아. 당신을 연결하는 증오하는 사람들은 모두 내 담당자를 쥐고 있습니다. 다음은 문자열 연결없이이를 수행하는 '적절한'방법입니다. 그러나 일반 테이블이있는 일반 페이지는 어리석은 Google과 같은 규모 이외의 성능 문제를 나타내지 않을 것이라고 생각합니다.

var sb = new System.Text.StringBuilder();
sb.Append("<table class='colorful'>");
foreach (var item in collection)
{
     sb.Append("<tr>");
     sb.Append("<td class='boldCell'>" + item.PropWhatever + "</td>");
     // more cells here as needed
     sb.Append("</tr>");
}
sb.Append("</table>");
placeholder1.InnerHtml = sb.ToString();

3
루프에서 문자열을 연결하기 위해 +를 사용하는 -1은 최악의 일입니다.
Daniel Little


글쎄, 우선, +=이런 식으로 루프 내부를 사용 하면 전혀 확장되지 않습니다. 문자열은 변경할 수 없기 때문에 매번 새로운 문자열을 만듭니다. StringBuilder대신 사용하십시오 .
Robert Harvey

3
끔찍한 코드를 작성하는 사람들이 다른 사람들과 끔찍한 코드를 공유해야하는 이유는 무엇입니까?
Ramhound

3
@Ramhound If you think a designer might ever have to tweak your HTML, use simple strings like this.이해하기 어려운 것은 무엇입니까 ? 끔찍한 코드에 대한 일부 사람들의 정의는 완전히 이해하는 데 몇 초가 걸리는 비용으로 밀리 초의 성능을 구입하는 것입니다. 개인의 최저 공통 분모로 코드를 보거나 유지할 것으로 예상되는 경우, 이해하기 쉽고 조정하기 쉬운 코드를 작성하는 것이 항상 가장 깨끗하거나 성능이 뛰어난 코드보다 낫다는 것이 가장 확실합니다.
maple_shaft
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.