McSaesch Geschrieben 8. August 2012 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
LordHexa Geschrieben 8. August 2012 Geschrieben 8. August 2012 Hallo McSaesch, spontan würde ich es so versuchen: var apiUrl = "api/project/" + projectId; [/PHP] Zitieren
McSaesch Geschrieben 9. August 2012 Autor 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
LordHexa Geschrieben 9. August 2012 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
etreu Geschrieben 9. August 2012 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
LordHexa Geschrieben 9. August 2012 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
LordHexa Geschrieben 6. September 2012 Geschrieben 6. September 2012 Gibt es hier ein Update? Zitieren
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.