如何解决:在线保存共享点中当前用户和状态的筛选查询

时间:2019-07-04 08:59:51

标签: javascript sharepoint sharepoint-online csom sp.js

我使用“ SP.js CSOM SP.ClientContext”按当前用户ID和状态过滤了查找字段,并成功过滤了查找。但是尝试保存时出现错误“对不起,出现了问题”,其关联ID为“ 9b40ec9e-1004-8000-bbff-36490b07f284”。 注意:如果我取消过滤,就可以保存。

我尝试使用其他过滤方法,使用CAML查询和JSOM Ajax调用。所有筛选均成功,但保存无效。

  SP.SOD.executeFunc('sp.js', 'SP.ClientContext', sharePointReady);

  function sharePointReady(){
     getItemsFromView("Activity Plan", "Approved",
         function(items){
             var field = getField("select", "My Planned Tasks")

              for(var i = 0; i < items.get_count(); i++){
                  var item = items.get_item(i);
                  var node = document.createElement("option");
                  var textnode = document.createTextNode(item.get_item('Deliverable'));
                  node.appendChild(textnode);
                  field.appendChild(node);

               }
           },
           function(sender,args){ 
              console.log(args.get_message())
           }
       );
    }

  function getItemsFromView(listTitle, viewTitle,success,error){
     var ctx = new SP.ClientContext();
     var list = ctx.get_web().get_lists().getByTitle(listTitle);
     var view = list.get_views().getByTitle(viewTitle);
     ctx.load(view,'ViewQuery');
     ctx.executeQueryAsync(
         function() {
             var viewQry = "<View><Query>" + view.get_viewQuery() + "</Query> 
  </View>";
             getItems(listTitle,viewQry,success,error);
          },
          error);
   }

  function getItems(listTitle, queryText,success,error) {
     var ctx = new SP.ClientContext();
     var list = ctx.get_web().get_lists().getByTitle(listTitle);
     var query = new SP.CamlQuery();
     query.set_viewXml(queryText);
     var items = list.getItems(query);
     ctx.load(items);
     ctx.executeQueryAsync(
         function() {
             success(items);
         },
         error
    );
  }

  function getField(fieldType,fieldTitle) {
       var docTags = document.getElementsByTagName(fieldType);
       for (var i=0; i < docTags.length; i++) {
           if (docTags[i].title == fieldTitle) {
               while (docTags[i].firstChild) {
               docTags[i].removeChild(docTags[i].firstChild);
             }
             return docTags[i];
           }
       }
       return false;
  }

我希望它保存在日历事件列表中,但我收到错误消息“对不起,出了点问题”和相关ID“ 9b40ec9e-1004-8000-bbff-36490b07f284”

1 个答案:

答案 0 :(得分:1)

您没有为该选项输入值。因此,这就像一个没有ID而只有文本的选项,因此需要替换此部分

  var textnode = document.createTextNode(item.get_item('Deliverable'));
                  node.appendChild(textnode);

带有以下内容

  var textnode = document.createTextNode(item.get_item('Deliverable'));
                  node.value = item.get_item('ID');
                  node.appendChild(textnode);