通过c#后面的代码迭代div

时间:2018-03-10 06:36:31

标签: c# innerhtml

任何人都知道如何减少冗余?我需要使用相同的内容填充客户端上多个div元素的内部html。

客户端:

<div id="projectList_dialog1" class="listView" runat="server"></div>
<div id="projectList_dialog2" class="listView" runat="server"></div>

代码背后:

protected void loadProjectList()
    {
        var projectsPath = userDataPath + @"\" + username + @"\Projects";

        if (Directory.Exists(projectsPath))
        {
            var projects = Directory.GetDirectories(userDataPath + @"\" + username + @"\Projects");

            projectList_dialog1.InnerHtml = "<table>";
            projectList_dialog2.InnerHtml = "<table>";

            projectList_dialog1.InnerHtml += "<tr><td>Name</td><td>Date modified</td></tr>";
            projectList_dialog2.InnerHtml += "<tr><td>Name</td><td>Date modified</td></tr>";

            List<string> storedProjectNamesList = new List<string>();
            for (var i = 0; i < projects.Length; i++)
            {
                var storedProjectName = projects[i].Remove(0, projects[i].LastIndexOf('\\') + 1);
                storedProjectNamesList.Add('"' + storedProjectName + '"');

                var lastModified = System.IO.File.GetLastWriteTime(storedProjectName);
                projectList_dialog1.InnerHtml += "<tr class='" + storedProjectName + "' onclick='listViewAction(event)'><td>" + storedProjectName + "</td><td>" + lastModified + "</td></tr>";
                projectList_dialog2.InnerHtml += "<tr class='" + storedProjectName + "' onclick='listViewAction(event)'><td>" + storedProjectName + "</td><td>" + lastModified + "</td></tr>";
            }
            projectList_dialog1.InnerHtml += "</table>";
            projectList_dialog2.InnerHtml += "</table>";

            storedProjectNames = string.Join(",", storedProjectNamesList);
        }
        else
        {
            serverMessage.InnerHtml = "Code (0x3): The system cannot find the path specified.";
        }
    }

1 个答案:

答案 0 :(得分:1)

将数据分配给innerHtml等本地变量,只更改元素的InnerHtml

protected void loadProjectList()
{
    var projectsPath = userDataPath + @"\" + username + @"\Projects";

    if (Directory.Exists(projectsPath))
    {
        var projects = Directory.GetDirectories(userDataPath + @"\" + username + @"\Projects");

        //create a variable
        var innerHtml = "<table><tr><td>Name</td><td>Date modified</td></tr>";

        List<string> storedProjectNamesList = new List<string>();
        for (var i = 0; i < projects.Length; i++)
        {
            var storedProjectName = projects[i].Remove(0, projects[i].LastIndexOf('\\') + 1);
            storedProjectNamesList.Add('"' + storedProjectName + '"');

            var lastModified = System.IO.File.GetLastWriteTime(storedProjectName);

            //add to that variable
            innerHtml += "<tr class='" + storedProjectName + "' onclick='listViewAction(event)'><td>" + storedProjectName + "</td><td>" + lastModified + "</td></tr>";
        }
        innerHtml += "</table>";

        //NOW set innerhtml on the objects
        projectList_dialog1.InnerHtml = innerHtml;
        projectList_dialog2.InnerHtml = innerHtml;

        storedProjectNames = string.Join(",", storedProjectNamesList);
    }
    else
    {
        serverMessage.InnerHtml = "Code (0x3): The system cannot find the path specified.";
    }
}