AJAX ControlToolkit学习日志-PagingBulletedListExtender(19)
         PagingBulletedListExtender控件用于对BulletedList服务端控件进行扩展,使其具有排序的功能。
下面看一个示例:
1)在VS2005中新建一个ASP.NET AJAX-Enabled Web Project工程项目,命名为PagingBulletedListExtender1。
2)在页面上添加一个BulletedList控件,并对其添加一些ListItem。
3)然后在页面上拖放一个PagingBulletedListExtender控件,提供BulletedList排序的功能。
代码如下:
属性说明:
BehaviorID:该控件在客户端的标识号。
TargetControlID:该控件要关联的BulletedList控件。
ClientSort:该控件是否允许BulletedList在客户端进行排序。
IndexSize:在BulletedList中索引项的字符个数。
MaxItemPerPage:BulletedList中显示的每页的最大项数。
      
4)然后再添加一些Radio和CheckBox,对控件进行不同的控制。
代码如下:
5)最后在页面中添加客户端的脚本代码,用于相应客户端的操作。
代码如下:
6)按下CTRL+F5,在浏览器中查看效果。
效果图如下:
![]()
下面看一个示例:
1)在VS2005中新建一个ASP.NET AJAX-Enabled Web Project工程项目,命名为PagingBulletedListExtender1。
2)在页面上添加一个BulletedList控件,并对其添加一些ListItem。
3)然后在页面上拖放一个PagingBulletedListExtender控件,提供BulletedList排序的功能。
代码如下:
1![]() <cc1:PagingBulletedListExtender ID="PagingBulletedListExtender1" BehaviorID="PagingBulletedListBehavior1" TargetControlID="BulletedList1" ClientSort="true" IndexSize="1" MaxItemPerPage="20" runat="server">
        <cc1:PagingBulletedListExtender ID="PagingBulletedListExtender1" BehaviorID="PagingBulletedListBehavior1" TargetControlID="BulletedList1" ClientSort="true" IndexSize="1" MaxItemPerPage="20" runat="server">
2![]() </cc1:PagingBulletedListExtender>
        </cc1:PagingBulletedListExtender>
3![]()
 <cc1:PagingBulletedListExtender ID="PagingBulletedListExtender1" BehaviorID="PagingBulletedListBehavior1" TargetControlID="BulletedList1" ClientSort="true" IndexSize="1" MaxItemPerPage="20" runat="server">
        <cc1:PagingBulletedListExtender ID="PagingBulletedListExtender1" BehaviorID="PagingBulletedListBehavior1" TargetControlID="BulletedList1" ClientSort="true" IndexSize="1" MaxItemPerPage="20" runat="server">2
 </cc1:PagingBulletedListExtender>
        </cc1:PagingBulletedListExtender>3

属性说明:
BehaviorID:该控件在客户端的标识号。
TargetControlID:该控件要关联的BulletedList控件。
ClientSort:该控件是否允许BulletedList在客户端进行排序。
IndexSize:在BulletedList中索引项的字符个数。
MaxItemPerPage:BulletedList中显示的每页的最大项数。
4)然后再添加一些Radio和CheckBox,对控件进行不同的控制。
代码如下:
 1![]() <input id="radioOption1" name="radioOption" type="radio"
        <input id="radioOption1" name="radioOption" type="radio" 
2![]() value="1" onclick="onChangeSelectOption()" />
            value="1" onclick="onChangeSelectOption()" />
3![]() <label for="radioOption1">Index size 1</label>
        <label for="radioOption1">Index size 1</label>
4![]() <input id="radioOption3" name="radioOption" type="radio"
        <input id="radioOption3" name="radioOption" type="radio" 
5![]() value="3" onclick="onChangeSelectOption()" />
            value="3" onclick="onChangeSelectOption()" />
6![]() <label for="radioOption3">10 Items per page</label><br />
        <label for="radioOption3">10 Items per page</label><br />
7![]() <input id="radioOption2" name="radioOption" type="radio"
        <input id="radioOption2" name="radioOption" type="radio" 
8![]() value="2" onclick="onChangeSelectOption()" />
            value="2" onclick="onChangeSelectOption()" />
9![]() <label for="radioOption2">Index size 2</label>
        <label for="radioOption2">Index size 2</label>
10![]() <input id="radioOption4" name="radioOption" type="radio"
        <input id="radioOption4" name="radioOption" type="radio" 
11![]() value="4" onclick="onChangeSelectOption()" />
            value="4" onclick="onChangeSelectOption()" />
12![]() <label for="radioOption4">20 Items per page</label> <br />
        <label for="radioOption4">20 Items per page</label> <br />
13![]() <input type="checkbox" id="clientSort"
        <input type="checkbox" id="clientSort" 
14![]() onclick="onChangeClientSort()" />
            onclick="onChangeClientSort()" />
15![]() <label for="clientSort">Sort</label>
        <label for="clientSort">Sort</label>
 <input id="radioOption1" name="radioOption" type="radio"
        <input id="radioOption1" name="radioOption" type="radio" 2
 value="1" onclick="onChangeSelectOption()" />
            value="1" onclick="onChangeSelectOption()" />3
 <label for="radioOption1">Index size 1</label>
        <label for="radioOption1">Index size 1</label>4
 <input id="radioOption3" name="radioOption" type="radio"
        <input id="radioOption3" name="radioOption" type="radio" 5
 value="3" onclick="onChangeSelectOption()" />
            value="3" onclick="onChangeSelectOption()" />6
 <label for="radioOption3">10 Items per page</label><br />
        <label for="radioOption3">10 Items per page</label><br />7
 <input id="radioOption2" name="radioOption" type="radio"
        <input id="radioOption2" name="radioOption" type="radio" 8
 value="2" onclick="onChangeSelectOption()" />
            value="2" onclick="onChangeSelectOption()" />9
 <label for="radioOption2">Index size 2</label>
        <label for="radioOption2">Index size 2</label>10
 <input id="radioOption4" name="radioOption" type="radio"
        <input id="radioOption4" name="radioOption" type="radio" 11
 value="4" onclick="onChangeSelectOption()" />
            value="4" onclick="onChangeSelectOption()" />12
 <label for="radioOption4">20 Items per page</label> <br />
        <label for="radioOption4">20 Items per page</label> <br />13
 <input type="checkbox" id="clientSort"
        <input type="checkbox" id="clientSort" 14
 onclick="onChangeClientSort()" />
            onclick="onChangeClientSort()" />15
 <label for="clientSort">Sort</label>
        <label for="clientSort">Sort</label>5)最后在页面中添加客户端的脚本代码,用于相应客户端的操作。
代码如下:
 1![]() var b1;
        var b1;
2![]() 
        
3![]() function pageLoad()
        function pageLoad()
4![]() {
        {
5![]() b1=$find('PagingBulletedListBehavior1');
            b1=$find('PagingBulletedListBehavior1');
6![]() if(b1.get_IndexSize()==1)   $get('radioOption1').checked=true;
            if(b1.get_IndexSize()==1)   $get('radioOption1').checked=true;
7![]() if(b1.get_IndexSize()==2)   $get('radioOption2').checked=true;
            if(b1.get_IndexSize()==2)   $get('radioOption2').checked=true;
8![]() if(b1.get_MaxItemPerPage()==10)   $get('radioOption3').checked=true;
            if(b1.get_MaxItemPerPage()==10)   $get('radioOption3').checked=true;
9![]() if(b1.get_MaxItemPerPage()==20)   $get('radioOption4').checked=true;
            if(b1.get_MaxItemPerPage()==20)   $get('radioOption4').checked=true;
10![]() $get('clientSort').checked=b1.get_ClientSort();
            $get('clientSort').checked=b1.get_ClientSort();
11![]() }
        }
12![]() 
        
13![]() function onChangeSelectOption()
        function onChangeSelectOption()
14![]() {
        {
15![]() if($get('radioOption1').checked)
            if($get('radioOption1').checked)
16![]() {
            {
17![]() b1.set_IndexSize(1);
                b1.set_IndexSize(1);
18![]() b1.set_MaxItemPerPage(null);
                b1.set_MaxItemPerPage(null);
19![]() }
            }
20![]() if($get('radioOption2').checked)
            if($get('radioOption2').checked)
21![]() {
            {
22![]() b1.set_IndexSize(2);
                b1.set_IndexSize(2);
23![]() b1.set_MaxItemPerPage(null);
                b1.set_MaxItemPerPage(null);
24![]() }
            }
25![]() if($get('radioOption3').checked)
            if($get('radioOption3').checked)
26![]() {
            {
27![]() b1.set_MaxItemPerPage(10);
                b1.set_MaxItemPerPage(10);
28![]() }
            }
29![]() if($get('radioOption4').checked)
            if($get('radioOption4').checked)
30![]() {
            {
31![]() b1.set_MaxItemPerPage(20);
                b1.set_MaxItemPerPage(20);
32![]() }
            }
33![]() }
        }
34![]() 
        
35![]() function onChangeClientSort()
        function onChangeClientSort()
36![]() {
        {
37![]() b1.set_ClientSort($get('clientSort').checked);
            b1.set_ClientSort($get('clientSort').checked);
38![]() }
        }
 var b1;
        var b1;2
 
        3
 function pageLoad()
        function pageLoad()4
 {
        {5
 b1=$find('PagingBulletedListBehavior1');
            b1=$find('PagingBulletedListBehavior1');6
 if(b1.get_IndexSize()==1)   $get('radioOption1').checked=true;
            if(b1.get_IndexSize()==1)   $get('radioOption1').checked=true;7
 if(b1.get_IndexSize()==2)   $get('radioOption2').checked=true;
            if(b1.get_IndexSize()==2)   $get('radioOption2').checked=true;8
 if(b1.get_MaxItemPerPage()==10)   $get('radioOption3').checked=true;
            if(b1.get_MaxItemPerPage()==10)   $get('radioOption3').checked=true;9
 if(b1.get_MaxItemPerPage()==20)   $get('radioOption4').checked=true;
            if(b1.get_MaxItemPerPage()==20)   $get('radioOption4').checked=true;10
 $get('clientSort').checked=b1.get_ClientSort();
            $get('clientSort').checked=b1.get_ClientSort();11
 }
        }12
 
        13
 function onChangeSelectOption()
        function onChangeSelectOption()14
 {
        {15
 if($get('radioOption1').checked)
            if($get('radioOption1').checked)16
 {
            {17
 b1.set_IndexSize(1);
                b1.set_IndexSize(1);18
 b1.set_MaxItemPerPage(null);
                b1.set_MaxItemPerPage(null);19
 }
            }20
 if($get('radioOption2').checked)
            if($get('radioOption2').checked)21
 {
            {22
 b1.set_IndexSize(2);
                b1.set_IndexSize(2);23
 b1.set_MaxItemPerPage(null);
                b1.set_MaxItemPerPage(null);24
 }
            }25
 if($get('radioOption3').checked)
            if($get('radioOption3').checked)26
 {
            {27
 b1.set_MaxItemPerPage(10);
                b1.set_MaxItemPerPage(10);28
 }
            }29
 if($get('radioOption4').checked)
            if($get('radioOption4').checked)30
 {
            {31
 b1.set_MaxItemPerPage(20);
                b1.set_MaxItemPerPage(20);32
 }
            }33
 }
        }34
 
        35
 function onChangeClientSort()
        function onChangeClientSort()36
 {
        {37
 b1.set_ClientSort($get('clientSort').checked);
            b1.set_ClientSort($get('clientSort').checked);38
 }
        }6)按下CTRL+F5,在浏览器中查看效果。
效果图如下:
 
                    
                

 
        
 
             
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号