3

現在、私のWebページでは、次のように画像をListViewオブジェクトにロードしています...

 <ContentTemplate>
            <asp:ListView ID="ListView1" runat="server">
                <layouttemplate>
                    <asp:PlaceHolder id="itemPlaceholder" runat="server" />
                </layouttemplate>
                <ItemTemplate>
                        <td>
                            <asp:Image ID="Image1" runat="server"  
                    ImageUrl = '<%# DataBinder.Eval(Container.DataItem, "Image") %>' />
                        </td>
                    </tr>
                </ItemTemplate>
            </asp:ListView>
 </ContentTemplate>

ここで、Generic HandlerとListViewオブジェクトの組み合わせを使用して、画像をListViewに提供したいと思います。

...一般的なハンドラー呼び出しは次のようなものです

~/Handlers/Image.ashx?img=

上記の両方を組み合わせて画像を提供するにはどうすればよいですか?

次のようなことを試しましたが、正しくありません

<asp:Image ID="Image1" runat="server"  
                        ImageUrl = ~/Handlers/Image.ashx?img= & '<%# DataBinder.Eval(Container.DataItem, "Image") %>' />

では、正しい方法は何ですか?

4

2 に答える 2

1

Yes that is the correct way. Your syntax for binding the ImageUrl not correct though. Try this one:

<asp:Image ID="Image1" runat="server" ImageUrl ='<%# "~/Handlers/Image.ashx?img=" + Eval("Image")%>' />

You might also use the ItemDataBound event to use code like this:

Image image1 = e.FindControl("Image1") as Image;
YourClass item = e.DataItem as YourClass;
image1.ImageUrl = String.Format("~/Handlers/Image.ashx?img={0}", item.Image")
于 2011-02-27T07:49:50.877 に答える
0

これを試して

<ItemTemplate>
<asp:Hyperlink runat= "server" Text='<%#DataBinder.Eval(Container.DataItem,"ProductName").ToString()%>'                               NavigateUrl='<%# "page.aspx?Name=" & DataBinder.Eval (Container.DataItem,"ProductName").tostring %>' ID="ProductName"/>   
</ItemTemplate>

それが役に立てば幸い

ソース: http: //www.extremeexperts.com/Net/FAQ/PassingMulitpleParameterinURLLink.aspx

于 2011-02-27T07:47:34.883 に答える