McSaesch Geschrieben 8. August 2012 Teilen Geschrieben 8. August 2012 Hallo, ich steh gerade ein wenig auf'm Schlauch... Das Script innerhalb der Seite: <script type="text/javascript" src="../../Scripts/jquery-1.7.2.min.js"></script> <script type="text/javascript"> $(document).ready(function(){ getAllProjects(function (projects) { var resultStr = ""; var guidString = ""; $.each(projects, function (index, project) { resultStr += '<li>ProjektId: ' + project.Id; resultStr += ' Projektname: ' + project.Name + '<br />'; resultStr += '<input type="button" value="Löschen" onclick="deleteProject(' + String(project.Id) + ')"/>'; }); $('#resultList').html(resultStr); }); }); function getAllProjects(callback) { $.ajax({ url: "/api/Project", data: {}, type: "GET", contentType: "application/json;charset=utf-8", statusCode: { 200: function (projects) { callback(projects); }, 404: function () { alert("Not found"); } } }).then(function(projects){ callback(projects); }); } function deleteProject(projectId) { // var guidString = String(projectId); var apiUrl = "api/project/{0}"; apiUrl = apiUrl.replace("{0}", projectId); $.ajax({ url: apiUrl, data: { }, type: "DELETE", cache: false, contentType: "application/json;charset=utf-8", statusCode: { 200: function (data) {}, 404: function (data) {alert("Not found");}, 400: function (data) {alert("Bad request");} }}); } </script> Die Seite lässt sich aufrufen, die Daten werden geladen, alles so wie es sein soll. Nur beim Löschen-Aufruf bekomme ich folgende Fehlermeldung im FireBug angezeigt: SyntaxError: identifier starts immediately after numeric literal Wie kann ich die GUID Id als Parameter übergeben ohne dass sie (anscheinend) geparst wird?! Einfach nur als String funktioniert nicht.... Danke + Gruß Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
LordHexa Geschrieben 8. August 2012 Teilen Geschrieben 8. August 2012 Hallo McSaesch, spontan würde ich es so versuchen: var apiUrl = "api/project/" + projectId; [/PHP] Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
McSaesch Geschrieben 9. August 2012 Autor Teilen Geschrieben 9. August 2012 Das war es nicht, aber danke für den Einwurf. Ich nehme mal an dass es beim Aufruf der function schon das Problem gibt... Im Anhang findet ihr die Darstellung im aus'm FireBug Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
LordHexa Geschrieben 9. August 2012 Teilen Geschrieben 9. August 2012 Ich hab grade noch mal ein wenig rumprobiert, mit einem äquivalenten Codeschnippsel. Funktioniert nicht: var projectIds = ['a8a3ee46-0ca0-4e0a-ac8e-81e3343901b', 'b8a3ee46-0ca0-4e0a-ac8e-81e3343901b', 'c8a3ee46-0ca0-4e0a-ac8e-81e3343901b']; for (var projectId in projectIds) document.write('<input type="button" value="Löschen" onclick="deleteProject(' + projectIds[projectId] + ')"/>'); function deleteProject(projectId){ alert(projectId); } [/PHP] Funktioniert: [PHP] var projectIds = ['a8a3ee46-0ca0-4e0a-ac8e-81e3343901b', 'b8a3ee46-0ca0-4e0a-ac8e-81e3343901b', 'c8a3ee46-0ca0-4e0a-ac8e-81e3343901b']; for (var projectId in projectIds) document.write('<input type="button" value="Löschen" onclick="deleteProject(\'' + projectIds[projectId] + '\')"/>'); function deleteProject(projectId){ alert(projectId); } Dardurch, das die ProjektId einfach noch mal in '' gesetzt wird, wird explizit festgelegt, das es sich um einen String handelt. Denke das ganze sollte bei deinem Fall auch funktionieren Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
etreu Geschrieben 9. August 2012 Teilen Geschrieben 9. August 2012 Dardurch, das die ProjektId einfach noch mal in '' gesetzt wird, wird explizit festgelegt, das es sich um einen String handelt. Denke das ganze sollte bei deinem Fall auch funktionieren Mehr oder weniger richtig. Deine Funktion bekommt als Parameter einen String übergeben. Wenn du das HTML von Hand schreiben würdest, dann sähe es auch in etwa so aus: deleteProject('guid') . In deiner Schleife baust du dir HTML-Code zusammen - damit muss das Ergebnis äquivalent sein. Du könntest genausgut folgendes nutzen: for (var projectId in projectIds) document.write('<input type="button" value="Löschen" onclick="deleteProject(projectIds[' + projectId + '])"/>'); [/PHP] In diesem Fall verkettet man weiterhin Strings, aber im generierten HTML verwendet man jetzt die Referenz auf das Array. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
LordHexa Geschrieben 9. August 2012 Teilen Geschrieben 9. August 2012 (bearbeitet) Mir ging es in meinem Beispiel nicht um die Schleife an sich, sondern darum das Problem von McSaesch zu lösen. EDIT: Um es noch mal zu verdeutlichen: Diese Zeile: resultStr += '<input type="button" value="Löschen" onclick="deleteProject(' + String(project.Id) + ')"/>'; [/PHP] folgendermaßen ändern: [PHP] resultStr += '<input type="button" value="Löschen" onclick="deleteProject(\'' + String(project.Id) + '\')"/>'; und das Problem sollte behoben sein. Beste Grüße Bearbeitet 9. August 2012 von LordHexa Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
LordHexa Geschrieben 6. September 2012 Teilen Geschrieben 6. September 2012 Gibt es hier ein Update? Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.