2014-09-19 3 views
4

Я пытаюсь использовать пример выбора сборщика из Office PnP.Uncaught ReferenceError: Тип не задан в sp.runtime.js

Я просто хочу привязать одно поле к одному управляемому термину метаданных.

Ошибки, которые я получил здесь: http://screencast.com/t/nOaTusUH4V

код у меня есть:

<head> 
    <meta charset="utf-8" /> 
    <title>Learning bootstrap</title>  
    <meta name="viewport" content="width=device-width, initial-scale=1"> 

    <link href="../Content/bootstrap.min.css" rel="stylesheet" /> 
    <link href="../Content/bootstrap-theme.min.css" rel="stylesheet" /> 
    <link rel="Stylesheet" type="text/css" href="../Content/taxonomypickercontrol.css" /> 
    <script src="../Scripts/jquery-2.1.1.min.js"></script> 
    <script type="text/javascript" src="/_layouts/15/sp.runtime.js"></script> 
    <script type="text/javascript" src="/_layouts/15/sp.js"></script> 

    <script src="../Scripts/app.js" type="text/javascript"></script> 
    <script src="../Scripts/taxonomypickercontrol.js" type="text/javascript"></script> 
</head> 


body> 
    <div id="divSPChrome"></div> 
    <div class="container">  
     <div class="row"> 
      <div class="col-md-8"> 
       <h2>Create project site</h2> 
       <form class="form-horizontal" role="form"> 
        <div class="form-group"> 
         <label for="inputEmail3" class="col-sm-2 control-label">Project name</label> 
         <div class="col-sm-10"> 
          <input type="text" class="form-control" id="inputEmail3" placeholder="Project name"> 
         </div> 
        </div> 
        <div class="form-group"> 
         <label for="inputPassword3" class="col-sm-2 control-label">Domain</label> 
         <div class="col-sm-10"> 
          <input type="text" class="form-control" id="inputPassword3" placeholder="Domain"> 
          <div class="ms-core-form-line" style="margin-bottom: 0px;"> 
           <input type="hidden" id="taxPickerContinent" /> 

          </div> 
         </div> 
        </div> 

Как вы можете видеть, у меня есть скрытое поле. И мой App.js файл:

// variable used for cross site CSOM calls 
var context; 
// variable to hold index of intialized taxPicker controls 
var taxPickerIndex = {}; 

//Wait for the page to load 
$(document).ready(function() { 

    //Get the URI decoded SharePoint site url from the SPHostUrl parameter. 
    var spHostUrl = decodeURIComponent(getQueryStringParameter('SPHostUrl')); 
    var appWebUrl = decodeURIComponent(getQueryStringParameter('SPAppWebUrl')); 
    var spLanguage = decodeURIComponent(getQueryStringParameter('SPLanguage')); 

    //Build absolute path to the layouts root with the spHostUrl 
    var layoutsRoot = spHostUrl + '/_layouts/15/'; 

    //load all appropriate scripts for the page to function 
    $.getScript(layoutsRoot + 'SP.Runtime.js', 
     function() { 
      $.getScript(layoutsRoot + 'SP.js', 
       function() { 
        //Load the SP.UI.Controls.js file to render the App Chrome 
        $.getScript(layoutsRoot + 'SP.UI.Controls.js', renderSPChrome); 

        //load scripts for cross site calls (needed to use the people picker control in an IFrame) 
        $.getScript(layoutsRoot + 'SP.RequestExecutor.js', function() { 
         context = new SP.ClientContext(appWebUrl); 
         var factory = new SP.ProxyWebRequestExecutorFactory(appWebUrl); 
         context.set_webRequestExecutorFactory(factory); 
        }); 

        //load scripts for calling taxonomy APIs 
        $.getScript(layoutsRoot + 'init.js', 
         function() { 
          $.getScript(layoutsRoot + 'sp.taxonomy.js', 
           function() { 
            //bind the taxonomy picker to the default keywords termset 
            //$('#taxPickerKeywords').taxpicker({ isMulti: true, allowFillIn: true, useKeywords: true }, context); 

            $('#taxPickerContinent').taxpicker({ isMulti: false, allowFillIn: false, useKeywords: false, termSetId: "51f18389-f28a-4961-a903-ee535f7c620d", levelToShowTerms: 1 }, context, initializeCountryTaxPicker); 
            taxPickerIndex["#taxPickerContinent"] = 0; 
           }); 
         }); 
       }); 
     }); 
}); 

function initializeCountryTaxPicker() { 
    //if (this._selectedTerms.length > 0) { 
    // $('#taxPickerCountry').taxpicker({ isMulti: false, allowFillIn: false, useKeywords: false, termSetId: "0cc96f04-d32c-41e7-995f-0401c1f4fda8", filterTermId: this._selectedTerms[0].Id, levelToShowTerms: 2, useTermSetasRootNode: false }, context, initializeRegionTaxPicker); 
    // taxPickerIndex["#taxPickerCountry"] = 4; 
    //} 
} 

function initializeRegionTaxPicker() { 
    //if (this._selectedTerms.length > 0) { 
    // $('#taxPickerRegion').taxpicker({ isMulti: false, allowFillIn: false, useKeywords: false, termSetId: "0cc96f04-d32c-41e7-995f-0401c1f4fda8", filterTermId: this._selectedTerms[0].Id, levelToShowTerms: 3, useTermSetasRootNode: false }, context); 
    // taxPickerIndex["#taxPickerRegion"] = 5; 
    //} 
} 

function getValue(propertyName) { 
    if (taxPickerIndex != null) { 
     return taxPickerIndex[propertyName]; 
    } 
}; 

//function to get a parameter value by a specific key 
function getQueryStringParameter(urlParameterKey) { 
    var params = document.URL.split('?')[1].split('&'); 
    var strParams = ''; 
    for (var i = 0; i < params.length; i = i + 1) { 
     var singleParam = params[i].split('='); 
     if (singleParam[0] == urlParameterKey) 
      return singleParam[1]; 
    } 
} 

function chromeLoaded() { 
    $('body').show(); 
} 

//function callback to render chrome after SP.UI.Controls.js loads 
function renderSPChrome() { 
    var icon = decodeURIComponent(getQueryStringParameter('SPHostLogoUrl')); 

    //Set the chrome options for launching Help, Account, and Contact pages 
    var options = { 
     'appTitle': document.title, 
     'appIconUrl': icon, 
     'onCssLoaded': 'chromeLoaded()' 
    }; 

    //Load the Chrome Control in the divSPChrome element of the page 
    var chromeNavigation = new SP.UI.Controls.Navigation('divSPChrome', options); 
    chromeNavigation.setVisible(true); 
} 

ответ

7

Type определен в файле MicrosoftAjax.js. Вы можете получить доступ к нему с помощью следующей script тег, чтобы получить его от САШ CDN:

<script type="text/javascript" src="//ajax.aspnetcdn.com/ajax/4.0/1/MicrosoftAjax.js"></script> 

Вам не нужно ScriptManager.

1

заряжаются SP.Runtime.js и SP.js дважды. Однажды на голове и на документе готовы. Попробуйте удалить один из них, но ошибка может быть другой. Я вижу больше ошибок до 404.

+0

Я удалил их из html, но это ничего не изменило –

+0

Попробуйте добавить console.log (yourmessage) внутри функций, чтобы увидеть в точке ведьмы поднять ошибку, я думаю, что некоторые var не инициализированы. – Max

1

вам не хватает сценариста. Поместите его выше <div id="divSPChrome"></div>

<asp:ScriptManager ID="ScriptManager" runat="server" EnableCdn="True" /> 

Когда ваши работают в HTML-странице, просто пытаемся ссылаться на это после загрузки JQuery.

<script src="https://ajax.aspnetcdn.com/ajax/4.0/MicrosoftAjax.js" type="text/javascript"></script> 
+0

это html-страница, а не aspx-страница, и на странице нет элементов управления asp.net, зачем мне это нужно? –

1

Возможно, это связано с тем, как вы регистрируете скрипты. Реферируемые библиотеки должны быть зарегистрированы перед скриптами, которые их используют. Проще всего проверить свою страницу в браузере, вы увидите порядок загрузки.

 Смежные вопросы

  • Нет связанных вопросов^_^