为 ListView添加 CheckBox栏

转帖|其它|编辑:郝浩|2009-02-26 10:47:57.000|阅读 2370 次

概述:为 ListView添加 CheckBox栏,做法可能略有不同。但是应该大同小异。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

看博客园里的前辈们都在研究MOSS,我也来凑个热闹

今天我也为ListView添加CheckBox栏,和前辈们的做法可能略有不同。但是应该大同小异。 

首先写一个WINFORM,放一个BUTTON,在单击事件里面加入代码:

            string xml = "<Field Type=""Computed"" ReadOnly=""TRUE"" Name=""ListItemSelection"" DisplayName=""Selector"" Sortable=""FALSE"" Filterable=""FALSE"" EnableLookup=""FALSE"" SourceID=""http://schemas.microsoft.com/sharepoint/v3"" StaticName=""ListItemSelection""><FieldRefs><FieldRef Name=""ID"" /></FieldRefs><DisplayPattern><HTML><![CDATA[<input type=""checkbox"" name=""docchk"" onclick=""setValue()"" ]]></HTML><HTML><![CDATA[LItemId=""]]></HTML><Column Name=""ID"" HTMLEncode=""TRUE"" /><HTML><![CDATA[""/> ]]></HTML></DisplayPattern></Field>";

            SPSite site = new SPSite("http://qdoffice");

            SPWeb web = site.OpenWeb("koniambo");

            SPList list = web.Lists["技术性文件"];

            list.Fields.AddFieldAsXml(xml);

 

 

 

  通过上面的代码可以将在LIST中创建一个SPField。

注意两个要点:

  1、其中定义了CheckBox的HTML样式,并在CheckBox的单击事件中加入Onclick = setValue() ;

  2、注意给CheckBox增加NAME属性,以便后面可以通过JS对其进行取值。这里面我将它的NAME属性设成docchk

 接下来,使用SPD打开页面。在<asp:Content ContentPlaceHolderId="PlaceHolderMain">后面增加一个<Input type="hidden" value="" name="dochid">。然后将下面的这段JS放到页面可以引用的任意位置,通过Link或是直接嵌入到页面里都可以。

function getCheckboxValue(name)
{
    
var str = "";
    
var theEle = document.getElementsByName(name);
        
for(var i=0;i<theEle.length;i++)
        
{
            
if(theEle[i].checked == true)
            
{
                str 
+= theEle[i].LItemId + ",";
            }

        }

        str 
= str.substr(0,str.length-1);
        
return str;
}

function el(name)
{
    
var el;
    el 
= document.getElementById(name);
    
return el;
}

function setValue()
{
    
var count = document.getElementsByName("docchk").length;
   
var number = 0;    
    
var strValue="";
    
var arrayCheckbox = new Array(count);
        
        
for(i=0;i<count;i++)
        
{    
            arrayCheckbox[i] 
= eval("document.all('docchk')["+i+"]");
            
if(arrayCheckbox[i].checked==true)        
            
{        
                
++number;                
                strValue
+=arrayCheckbox[i].LItemId+ ",";        
            }
    
         }
       
        document.getElementsByName(
"dochid")[0].value=strValue.substr(0,strValue.length-1);
}

 

 这样的话你在点周CheckBo的话就可以通过SetValues方法向dochid域中写值了(值为用逗号隔开的ListItemID)。

在后台就可以取到值了。

 

 都做到这步了,后面的就自己发挥了。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:博客园

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP