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

    在后台就可以取到值了。

     

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

  • 相关阅读:
    为自己的开篇
    软考程序员笔记
    centos php7 安装mysqli扩展心得
    php判断访问协议是否是https
    go语言新建多维map集合
    获取contenteditable区域光标所在位置信息
    ckeditor中 config.js等通过ckeditor.js引入文件手动修改方法
    Vue使用——v-for循环里面使用v-if判断显示数据
    数据库关联字段设置
    Spring Jpa 自动建表——时间字段设置
  • 原文地址:https://www.cnblogs.com/scally/p/1395967.html
Copyright © 2011-2022 走看看