ShowModalDialog aus der von SharePoint gehosteten App funktioniert nicht
-
10-12-2019 - |
Frage
Ich habe das gleiche Problem wie in mehreren anderen Diskussionen:
Chrom:
Cannot read property 'defaultDialogWidth' of undefined
Feuerfuchs: SP.Res is undefined
https://sharepoint.stackexchange.com/posts/76044 http://social.msdn.microsoft.com/Forums/sharepoint/en-US/bf1dc5ea-c045-48f6-b0cd-144d0ab7c1ce/spreshiddenbuttonvaluebeforedialog-is-null-or-not-an-object?forum=sharepointdevelopment previous http://chuvash.eu/2012/02/13/scriptresx-ashx-in-sharepoint/
Ich habe verschiedene online veröffentlichte Lösungen ausprobiert, aber keine scheint zu funktionieren.Kann mir jemand sagen, welche Abhängigkeiten mir fehlen?(Ich verwende keine Masterseite)
Ich habe den folgenden Code:
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);
}
Und die folgenden Skripte wurden geladen:
<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>
Lösung
Ich habe die fehlenden Abhängigkeiten schließlich selbst gefunden, falls jemand jemals auf das gleiche Problem stoßen sollte, sind es die folgenden:
<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" />');
}
})();
Andere Tipps
Haben Sie diesen Link überprüft?
Darin wird Folgendes erwähnt:
Die Webseite, die Ihre App hostet, muss über Folgendes verfügen:
<WebPartPages:AllowFraming ID="AllowFraming1" runat="server" />
Hinzufügen _ribbon = new Object();
nach sp.ui.dialog.js
Skript geladen.
Beispiel:
<script type="text/javascript" src="/_layouts/15/sp.ui.dialog.js"></script>
<script type="text/javascript">
_ribbon = new Object();
</script>