使用repeater,遍历数据,不规则排序,不同的样式之间切换

如图最下面那副图片的文字说明在图片的右边,而其它图片的文字说明在图片的下方,要实现这种效果,其实只要在HTML部分用样式控制,就可以达到了。

 

前台代码:

先在CSS.CSS样式文件里定义二个更换的样式,

.class3{ position:absolute; left:310px; top:600px; width:280px;}

.class4{ }

<div id="main" >
<ul>

    <asp:Repeater ID="datalist" runat="server">
        <ItemTemplate>
                <li style="float:left;">
                         <div class='<%# (Container.ItemIndex) == 4 ? "class1" : "class2" %>'><img src="<%#Eval("imgUrl") %>" width="280px" height="180px" /></div><br />

                        <div  runat="server" class='<%# (Container.ItemIndex) == 4 ? "class3" : "class4" %>'><a href="newsDisplay.aspx?id=<%#Eval("ID") %>"><div style="margin-top:10px; font-size:12px;">
                            <span style="color:#9D6E31; font-size:16px;">><%#Eval("title") %></span><br />
                           <%#getContent(Eval("content").ToString()) %>
                        </div></a></div>
                </li>
        </ItemTemplate>
    </asp:Repeater>
    </ul>
</div>
最重要的就是 class='<%# (Container.ItemIndex) == 4 ? "class3" : "class4" %>',这句了,这句让数据行索引自己判断是到第几行了,用一个三元运算符判断选择哪个样式。


后台代码很简单,和普通的绑定一样。

代码
 
   
1 public partial class index : System.Web.UI.Page
2 {
3 aboutus us = new aboutus();
4 protected void Page_Load( object sender, EventArgs e)
5 {
6 bind();
7 }
8 protected string getContent( string str)
9 {
10 if (str.Length > 80 )
11 {
12 str = str.Substring( 0 , 80 ) + " ... " ;
13 }
14 return str;
15 }
16 protected void bind()
17 {
18 string sql = " select top 5 ID,title,content,imgUrl from main where type='ABOUTUS' order by [order] desc " ;
19 this .datalist.DataSource = DbHelperOleDb.Query(sql);
20 this .datalist.DataBind();
21 }

 

呵呵,很简单的,当时弄这个的时候头都想破了。问了好多人。

转载于:https://www.cnblogs.com/sheseido/archive/2010/10/31/1865770.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值