Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/google-app-engine/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sharepoint 2010 如何在sharepoint 2010中从拼写检查中排除字段?_Sharepoint 2010_Spell Checking - Fatal编程技术网

Sharepoint 2010 如何在sharepoint 2010中从拼写检查中排除字段?

Sharepoint 2010 如何在sharepoint 2010中从拼写检查中排除字段?,sharepoint-2010,spell-checking,Sharepoint 2010,Spell Checking,我在页面布局中有一个SharePointWebControl:UserField,需要从拼写检查中排除,否则每当选择用户时,就会在控件的代码中检测到大量拼写错误 在Sharepoint 2007中,似乎可以通过使用excludefromspellcheck=“true”实现此行为,但这似乎不适用于Sharepoint 2010。是否有人遇到过同样的问题并找到了解决方法?基于SpellCheckEntirePage.js,似乎仍然是这样: var elements=document.body.ge

我在页面布局中有一个
SharePointWebControl:UserField
,需要从拼写检查中排除,否则每当选择用户时,就会在控件的代码中检测到大量拼写错误


在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")
}

您可以通过将文本区域和不希望进行拼写检查的输入控件上的“excludeContentFromSpellCheck”属性设置为“true”来禁用某些字段的拼写检查

我在我所有的页面布局上都这样做了。现在我再也没有假阳性了

解决方案是在不希望拼写检查的字段周围添加一个div标记,并为div标记中的元素添加一个将“excludeFromSpellCheck”设置为“true”的javascript


这里描述了我找到的解决方案:

乔·弗纳发布了这个解决方案,它对我很有效。

它排除页面上的所有PeoplePicker:

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) {
    }
}
函数禁用SpellCheckOnPeoplePickers(){
var elements=document.body.getElementsByTagName(“*”);
对于(索引=0;索引
此代码仅部分工作,因为如果您再次输入人员选取器值,请检查人员选取器垃圾值一次。

需要花费更多的时间才能让普通javascript来完成此工作,而不是使用jQuery,但这种方法可以在所有呈现的html元素上设置属性。
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) {
    }
}