我在页面布局中有SharePointWebControls:UserField
需要从拼写检查中排除,否则每当选择用户时,在控件的代码隐藏中会检测到大量拼写错误。
似乎在Sharepoint 2007中,这种行为可以通过使用excludefromspellcheck = "true"
来实现,但这似乎不适用于Sharepoint 2010.有没有人遇到同样的问题并找到解决方法呢?
答案 0 :(得分:1)
基于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控件由多个元素组成。我会尝试查看View Source以查看excludeFromSpellCheck是否将其转换为最终的HTML。但是要在适当的元素上设置属性,您可能需要使用这样的jQuery:
$("(input|textarea)[id*='UserField']").attr("excludeFromSpellCheck", "true");
答案 1 :(得分:0)
您可以通过设置&#34; excludeContentFromSpellCheck&#34;来禁用某些字段的拼写检查。属于&#34; true&#34;在您不想拼写检查的文本区域和输入控件上。
我在所有页面布局上都这样做了。现在我再也不会得到误报了。
解决方案是在您不想要拼写检查的字段周围添加div标签,并添加设置&#34; excludeFromSpellCheck&#34;到&#34;真&#34;对于div标签中的元素。
我找到的解决方案如下所述:Inaccurate Spell Check on SharePoint Publishing Pages
答案 2 :(得分:0)
Joe 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) {
}
}
答案 3 :(得分:0)
此代码仅部分工作,因为如果您再次将人员选择器值检查人员选择器垃圾值一次。