jquery spservices更新列表项



我正在尝试使用jquery spservices更新列表项。一切都正常,但当我尝试将href添加到richtext字段时,它不起作用。它只更新纯文本而不更新href。下面是代码,这只是一个测试,所以这些url是用来测试的。

function fn_UpdateListItem(){
$().SPServices({
operation: 'UpdateListItems',
listName: 'Bedrijven',
ID: 1,
valuepairs: [["Software", "<a href='http://www.google.nl'>its a test.</a>"]],
completefunc: function(xData, Status) {
alert('test complete');
}
});
}

如果我将值对更改为

valuepairs: [["Software", "test"]],

它在富文本字段中进行测试。但是href不起作用。有人知道怎么修吗?提前感谢

我在Sharepoint 2010中遇到了同样的问题,在本例中var dfNotes=CKEDITOR.instances.notes.getData()对我不起作用,我发现了这个:

https://msdn.microsoft.com/en-us/library/office/ee658527(v=office.14).aspx

var value = SP.Utilities.HttpUtility.htmlEncode(html); 
编辑

Sharepoint 2016 Sharepoint内部部署上进行了测试,它也适用,所以我也应该适用于Sharepoint Online!!

这就是它对我的作用:

function AddListItem(html, list) { 
    var value = SP.Utilities.HttpUtility.htmlEncode(html);        
    $().SPServices({
        operation: "UpdateListItems",
        async: false,
        batchCmd: "New",
        listName: list,
        valuepairs: [["Title", 'Title'], ["Content", value]],
        completefunc: function(xData, Status) {
            console.log(Status);
        }
    });
} 

这是实际的解决方案。在提交到SharePoint列表之前,HTML化的数据存储在XML中,这不利于嵌入的HTML标记,因此需要对其进行转义。感谢SPServices论坛上的反馈,我能够确定上面的例子就是这样。

我修改了我的代码如下:

var dfNotes = CKEDITOR.instances.notes.getData();
$().SPServices({
    operation: "UpdateListItems",
    async: false,
    batchCmd: "Update",
    listName: list,
    ID: prog,
    valuepairs: [["Notes", $("#notes").text(dfNotes).html()]],
    completefunc: function (xData, Status) {
        alert($("#notes").html());
    }
});

第一行引用了一个富文本编辑器字段,该字段包含新修改的文本。请注意valuepairs行中的细微差异,它现在使用.text().html()来转义文本,以便通过XML进行传输。

我希望这能帮助到别人!

您需要对html代码进行编码(替换JavaScript:Escaping Special characters、&lt;&gt;的字符<和>;这是一些字符的示例),这样您就可以在富内容文本字段(Notes)中保存一个字符串,当项目更新时,您的数据将具有html代码。

这是代码:

function fn_UpdateListItem(){
    var link = htmlEscape('<a href='http://www.google.nl'>its a test.</a>');
    $().SPServices({
        operation: 'UpdateListItems',
        listName: 'Bedrijven',
        ID: 1,
        valuepairs: [["Software", link]],
        completefunc: function(xData, Status) {
            alert('test complete');
        }
     });
}
//This function makes the magic
function htmlEscape(str) {
    return String(str)
        .replace(/&/g, '&amp;')
        .replace(/"/g, '&quot;')
        .replace(/'/g, '&#39;')
        .replace(/</g, '&lt;')
        .replace(/>/g, '&gt;');
}

向致以最良好的问候

相关内容

  • 没有找到相关文章

最新更新