我正在尝试使用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、<
和>
的字符<和>;这是一些字符的示例),这样您就可以在富内容文本字段(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, '&')
.replace(/"/g, '"')
.replace(/'/g, ''')
.replace(/</g, '<')
.replace(/>/g, '>');
}
向致以最良好的问候