1

我正在尝试创建一个小型网络应用程序,当我输入游戏名称时,它会搜索一个包含大量图标的文件夹,以找到与输入游戏相似的图标。

然后我想显示一个带有图标名称的转发器,以及它旁边的图标。

到目前为止,我已经使用以下代码成功显示了名称:

IEnumerable<string> getfiles =
            from f in
                Directory.EnumerateFiles(Server.MapPath("~/_resources/game_icon"), "*.*", SearchOption.AllDirectories)
            where Path.GetFileName(f).ToLower().Contains(txtGameName.Text.ToLower())
            select Path.GetFileNameWithoutExtension(f);

        List<AllFiles> all = getfiles.Select(file => new AllFiles
            {
                FileName = file, 
                SubdirectoryName = "",
                FileNameWithExtension = ""
            }).ToList();

        rptGameMatches.DataSource = all;
        rptGameMatches.DataBind();

但是在显示图标方面没有太多运气,该图标将位于ImageLocation.

我试过玩:

foreach (string file in Directory.EnumerateFiles(Server.MapPath("~/_resources/game_icon"), "*.*", SearchOption.AllDirectories).Count() )
        {
            if(file.)
        }

for (int i = 0; i < Directory.EnumerateFiles(Server.MapPath("~/_resources/game_icon"), "*.*", SearchOption.AllDirectories).Count(); i++)
        {

        }

没有成功。

我知道有一种简单的方法可以做到这一点,但我似乎不能完全正确。有人可以告诉我哪里出错了吗?

4

1 回答 1

3

这是您可以做什么的示例(出于紧凑的原因,我将代码和标记放在单个 WebForm 中,但当然您可以将代码放在单独的文件中):

<%@ Page Language="C#" %>
<%@ Import Namespace="System.IO" %>

<script type="text/c#" runat="server">
    protected void BtnSearchClick(object sender, EventArgs e)
    {
        var images =
            from image in Directory.EnumerateFiles(Server.MapPath(folder), "*.*", SearchOption.AllDirectories)
            let relativeLocation = image.Replace(root, string.Empty).Replace("\\", "/")
            let url = ResolveUrl("~/" + relativeLocation)
            where image.ToLower().Contains(txtGameName.Text.ToLower())
            select new 
            {
                Url = url
            };

        results.DataSource = images;
        results.DataBind();
    }
</script>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:TextBox ID="txtGameName" runat="server" />
        <asp:LinkButton ID="btnSearch" runat="server" OnClick="BtnSearchClick" Text="Search" />
        <asp:Repeater ID="results" runat="server">
            <ItemTemplate>
                <asp:Image runat="server" ImageUrl='<%# Eval("Url") %>' />
            </ItemTemplate>
        </asp:Repeater>
    </div>
    </form>
</body>
</html>

好的,所以我们有一个包含文本字段、按钮和转发器的网页。单击按钮时,我们将搜索指定文件夹中名称包含输入文本字段中的文本的所有图像:

var images =
    from image in Directory.EnumerateFiles(Server.MapPath(folder), "*.*", SearchOption.AllDirectories)
    let relativeLocation = image.Replace(root, string.Empty).Replace("\\", "/")
    let url = ResolveUrl("~/" + relativeLocation)
    where image.ToLower().Contains(txtGameName.Text.ToLower())
    select new 
    {
        Url = url
    };

这里有几个步骤:

let filename = Path.GetFileName(image)

在这个阶段,我们正在获取文件的物理位置。它看起来像这样:

c:\inetpub\wwwroot\_resources\game_icon\image1.png

然后我们剥离应用程序根并替换斜杠:

let relativeLocation = filename.Replace(root, string.Empty).Replace("\\", "/")

所以relativeLocation变成:

_resources/game_icon/image1.png

最后一步是:

let url = ResolveUrl("~/" + relativeLocation)

这将变成:

/_resources/game_icon/image1.png

所以在一天结束时,图像集合可能看起来像这样(假设用户image在文本字段中搜索):

[
    { Url: "/_resources/game_icon/image1.png" },
    { Url: "/_resources/game_icon/subfolder1/image2.png" },
    { Url: "/_resources/game_icon/subfolder2/image1.png" },
    ...
]

正是这个集合绑定到转发器。在中继器内部,我们定义了一个 Image,其ImageUrl属性将是绑定到Url我们构造的匿名对象的属性的数据。

于 2013-01-15T06:53:40.673 回答