zoukankan      html  css  js  c++  java
  • 我也为ListView添加CheckBox栏

    看博客园里的前辈们都在研究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://SITENAME");

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

                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)。

    在后台就可以取到值了。

     

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

  • 相关阅读:
    Map
    input输入框文字提示IE兼容
    Linux下实现获取远程机器文件
    ssl_error_rx_record_too_long
    Linux下访问网站
    Linux安装Jdk1.7
    bootstrap左右圆角按钮-适配手机页面
    jQuery使用load方法加载其他文档内容
    Js操作DOM小练习_01
    BootstrapValidator验证表单用法
  • 原文地址:https://www.cnblogs.com/scally/p/1395967.html
Copyright © 2011-2022 走看看