Domanda

Sto avendo lo stesso problema come in più altre discussioni:

Chrome : Cannot read property 'defaultDialogWidth' of undefined

Firefox : SP.Res is undefined

https://sharepoint.stackexchange.com/posts/76044 http://social.mssdn.microsoft.com/forums/sharepoint/en-us/bf1dc5ea-c045-48f6-b0cd-144d0ab7c1ce/spreshesndenbuttonValuebeforedialog-is-nul-or-not- un oggetto? Forum= SharePointDevelopmentPrevious http://chuvash.eu/2012/02/13/sscripstresx -Shx-in-SharePoint /

Ho provato varie soluzioni pubblicate online ma nessuno sembra funzionare. Qualcuno può dirmi quali dipendenze mi mancano? (Non sto usando una masterpage)

Ho il seguente codice:

    function showTimeSheetLinesDialog(guid) {
        var options = {};
        options.width = 500;
        options.height = 640;
        //options.url = getQueryStringParameter('SPAppWebUrl') + '/Pages/TimeSheetLineDetail.aspx?guid=' + guid + '&json=' + $("#" + guid).attr('data-lines');
        options.title = 'Dialog title';
        options.allowMaximize = false;
        options.showClose = true;

        //SP.UI.ModalDialog.showModalDialog(options);
        ExecuteOrDelayUntilScriptLoaded(SP.SOD.execute('sp.ui.dialog.js', 'SP.UI.ModalDialog.showModalDialog', options), "SP.js")
        //SP.SOD.execute('sp.ui.dialog.js', 'SP.UI.ModalDialog.showModalDialog', options);


        // parent.SP.SOD.execute('sp.ui.dialog.js', 'SP.UI.ModalDialog.showModalDialog', options);

}
.

e i seguenti script caricati:

 <head>
    <base target="_parent" />
    <title></title>
    <script type="text/javascript" src="/_layouts/15/init.js"></script>
    <script type="text/javascript" src="../Scripts/jquery-1.8.2.min.js"></script>
    <script type="text/javascript" src="/_layouts/15/MicrosoftAjax.js"></script>
    <script type="text/javascript" src="/_layouts/15/sp.runtime.debug.js"></script>
    <script type="text/javascript" src="/_layouts/15/sp.debug.js"></script>
    <script type="text/javascript" src="/_layouts/15/ps.debug.js"></script>
    <script type="text/javascript" src="/_layouts/15/sp.ui.dialog.js"></script>
    <script type="text/javascript" src="../Scripts/moment.js"></script>
    <script type="text/javascript" src="/_layouts/15/sp.init.js"></script>
    <script src="/_layouts/15/ScriptResx.ashx?culture=nb-no&name=SP.Res"></script>


    <link href="../Content/bootstrap.min.css" rel="stylesheet">
    <link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap-glyphicons.css" rel="stylesheet">

    <script src="../Scripts/bootstrap.min.js"></script>
    <script src="../Scripts/Warning.js"></script>
</head>
.

È stato utile?

Soluzione

Alla fine ho trovato le dipendenze mancanti, in caso chiunque si imbatti in lo stesso problema, sono i seguenti:

 <script type="text/javascript" src="/_layouts/15/ScriptResx.ashx?culture=en%2Dus&name=SP%2ERes"></script>


<script type="text/javascript">
    'use strict';

    // Set the style of the client web part page to be consistent with the host web.
    (function () {
        var hostUrl = '';
        if (document.URL.indexOf('?') != -1) {
            var params = document.URL.split('?')[1].split('&');
            for (var i = 0; i < params.length; i++) {
                var p = decodeURIComponent(params[i]);
                if (/^SPHostUrl=/i.test(p)) {
                    hostUrl = p.split('=')[1];
                    document.write('<link rel="stylesheet" href="' + hostUrl + '/_layouts/15/defaultcss.ashx" />');
                    break;
                }
            }
        }
        if (hostUrl == '') {
            document.write('<link rel="stylesheet" href="/_layouts/15/1033/styles/themable/corev15.css" />');
        }
    })();
.

Altri suggerimenti

Hai controllato questo link?

http://social.mssdn.microsoft.com/forums/sharepoint/en-us/c3666CE1-E326-4DC2-AA58-20ADE46B2CCE / Open-A-Page-in-Modal-Dialog-From-SharePoint-Hosted-App-o-Auto-Hosted-App? Forum= AppsForsharePoint

menziona questo:

.

La pagina Web che ospita la tua app deve avere quanto segue:

<WebPartPages:AllowFraming ID="AllowFraming1" runat="server" />

Aggiungi _ribbon = new Object(); dopo lo script sp.ui.dialog.js caricato.

Esempio:

<script type="text/javascript" src="/_layouts/15/sp.ui.dialog.js"></script>

<script type="text/javascript">

    _ribbon = new Object();

</script>
.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a sharepoint.stackexchange
scroll top