CAML查询包含不起作用

时间:2015-03-03 14:17:51

标签: sharepoint sharepoint-2013 caml

我已经获得了此代码,该代码使用标题的一部分来执行查询并过滤列表内容的一部分:

<script type="text/javascript">

var items_lista; 

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

    function Initialize() {

        var PDP_Link_Filter = $("title").text().split("-")[1].split(".")[0];  

        PDP_Link_Filter = "Link_" + PDP_Link_Filter + "_"; 

        var contexto = SP.ClientContext.get_current();
        var web = contexto.get_web();
        var listas = web.get_lists();
        var parametros = listas.getByTitle('Parametrizacion_WF');

        var query = new SP.CamlQuery();

        query.set_viewXml("<Query><Where><Contains><FieldRef Name='Title'/>" + 
                          "<Value Type='Text'>" + PDP_Link_Filter + "</Value></Contains></Where></Query>");

        console.log(query);

        items_lista = parametros.getItems(query);
        contexto.load(items_lista);
        contexto.executeQueryAsync(Function.createDelegate(this, this.onRequestSucceeded), Function.createDelegate(this, this.onRequestFailed));

    } //Initialize 

    function onRequestSucceeded() 
    {
        console.log(items_lista); 
        for(i = 0; i < items_lista.get_count(); i++) 
        {
            console.log(items_lista.get_item(i).get_item('Title'));
        }       
    }
    function onRequestFailed() { console.log('Error'); }

</script>

它生成的查询过滤器(通过console.log()获得):

<Query><Where><Contains><FieldRef Name='Title'/><Value Type='Text'>P000</Value></Contains></Where></Query>

但是当for循环运行时,它会显示列表的所有内容,而不仅仅是与过滤器匹配的行。

我做错了什么?

1 个答案:

答案 0 :(得分:0)

这很可能与SP.CamlQuery.viewXml property的格式错误有关。由于此属性需要 XML模式来定义列表视图,因此 root 元素必须是View元素,例如:

var ctx = SP.ClientContext.get_current();
var list = ctx.get_web().get_lists().getByTitle(listTitle);
var items = list.getItems('<View Scope="RecursiveAll"><Query></Query></View>');

在您的情况下,使用View元素包含查询:

<View>
   <Query>...</Query>
</View>