我有一个SharePointWebControls:UserField
在页面布局中需要从拼写检查中排除,否则无论何时选择一个用户时,都会在代码隐藏中检测到大量拼写错误。如何从sharepoint 2010中的拼写检查中排除字段?
似乎在Sharepoint 2007中,这种行为可以通过使用excludefromspellcheck = "true"
来实现,但这似乎不适用于Sharepoint 2010.有没有人遇到同样的问题并找到解决方法?
我有一个SharePointWebControls:UserField
在页面布局中需要从拼写检查中排除,否则无论何时选择一个用户时,都会在代码隐藏中检测到大量拼写错误。如何从sharepoint 2010中的拼写检查中排除字段?
似乎在Sharepoint 2007中,这种行为可以通过使用excludefromspellcheck = "true"
来实现,但这似乎不适用于Sharepoint 2010.有没有人遇到同样的问题并找到解决方法?
基于SpellCheckEntirePage.js,这似乎仍然是这样:
var elements=document.body.getElementsByTagName("*");
for (index=0; index < elements.length;++index)
{
if (null !=elements[index].getAttribute("excludeFromSpellCheck"))
{
continue;
}
// snipped - if (elements[index].tagName=="INPUT")
// snipped - else if (elements[index].tagName=="TEXTAREA")
}
但excludeFromSpellCheck不是UserField的属性,所以它可能不会自动向下复制到呈现的HTML。呈现时,UserField控件由多个元素组成。我会尝试查看查看源代码,以查看excludeFromSpellCheck是否将其添加到最终的HTML中。但要设置相应的元素属性,您可能需要使用一些jQuery的是这样的:
$("(input|textarea)[id*='UserField']").attr("excludeFromSpellCheck", "true");
您可以通过文本区域设置“excludeContentFromSpellCheck”属性为“true”禁用某些领域的拼写检查并输入你不想被拼写检查的控件。
我在我的所有页面布局上都这样做了。现在我不再有误报。
解决方法是在不希望拼写检查的字段周围添加div标签,并添加一个javascript,将div标签中的元素的“excludeFromSpellCheck”设置为“true”。
我找到了解决方案说明如下:Inaccurate Spell Check on SharePoint Publishing Pages
乔Furner张贴了这个解决方案,这为我工作。
https://www.altamiracorp.com/blog/employee-posts/spell-checking-your-custom-lay
它排除了页面上的所有PeoplePickers:
function disableSpellCheckOnPeoplePickers() {
var elements = document.body.getElementsByTagName("*");
for (index = 0; index < elements.length; index++) {
if (elements[index].tagName == "INPUT" && elements[index].parentNode && elements[index].parentNode.tagName == "SPAN") {
var elem = elements[index];
if (elem.parentNode.getAttribute("NoMatchesText") != "") {
disableSpellCheckOnPeoplePickersAllChildren(elem.parentNode);
}
}
}
}
function disableSpellCheckOnPeoplePickersAllChildren(elem) {
try {
elem.setAttribute("excludeFromSpellCheck", "true");
for (var i = 0; i < elem.childNodes.length; i++) {
disableSpellCheckOnPeoplePickersAllChildren(elem.childNodes[i]);
}
}
catch(e) {
}
}
此代码工作仅部分,因为如果你把人员选取器值再次检查人员选取垃圾值一次。
花了一些戳,以获得正常的JavaScript来做这项工作,而不是使用jQuery,但这种方法工作设置所有呈现的HTML元素的属性。 – Stark 2011-03-07 16:31:24