0

データリストがあり、その中にハイパーリンクがあり、navigateurl で QueryString を使用したい。これは asp:DataList の DataSource です。

 public void GalleryListDS()
    {

        int UserID = Convert.ToInt32(ViewState["UserID"]);

        var n = from gi in DataContext.Context.GalleryImages
                join g in DataContext.Context.Galleries
                on gi.GalleryID equals g.GalleryID
                where g.UserID == UserID && gi.IsAlbumImage == true
                select new
                {
                    UserID=g.UserID,
                    GalleryID = g.GalleryID,
                    ImageDescription = gi.ImageDescription,
                    GalleryName=g.GalleryName,
                    ImageFileName = gi.ImageFileName
                };

        dlGalleryList.DataSource = n;
        dlGalleryList.DataBind();

    }

そして、これは私のDataListです:

 <asp:DataList ID="dlGalleryList" runat="server" RepeatColumns="3">
        <ItemTemplate>
            <div class="gallery">
              <asp:HyperLink ID="HyperLink1" runat="server" NavigateUrl='<%# Eval("GalleryID","~/Profile/UserImages.aspx?ImgID={0}") %>'>
                '<%# Eval("GalleryName")%>'
            </asp:HyperLink>
            </div>
        </ItemTemplate>
    </asp:DataList>

QueryString に次のような Parameter を持たせたい:

  <asp:HyperLink ID="HyperLink1" runat="server" NavigateUrl='<%# Eval("GalleryID","UserID","~/Profile/UserImages.aspx?ImgID={0}&ProfileID={1}") %>'>

しかし、これは望ましい結果を達成しません。

4

3 に答える 3

0

あなたはこのようにすることができます

<asp:HyperLink ID="HyperLink1" runat="server" NavigateUrl='<%= "~/Profile/UserImages.aspx?ImgID=" + Eval("GalleryID") + "&ProfileID=" + Eval("UserID") %>'>
于 2013-09-11T08:51:03.027 に答える