2016-03-24 5 views
1

Html:Bestätigungstaste Anlegen mit Sweetalert, Javascript und Laravel

<form id="myform" class="delete-photo col-md-12" method="POST" action="/admin/category/{{$catget->id}}"> 
     <input type="hidden" name="_method" value="delete">      
      {{ csrf_field() }}        
      <div class="form-group"> 
       <button type="submit" data-photo-id="{{$catget->id}}" 
       class="submitdel btn btn-danger" 
       >Delete Category</button> 
      </div>      
    </form> 

Js:

<script type="text/javascript"> 
$('.delete-photo').click(function(e) { 
    e.preventDefault(); // Prevent the href from redirecting directly 
    var linkURL = $(this).attr("action"); 
    warnBeforeRedirect(linkURL); 
}); 

function warnBeforeRedirect(linkURL) { 
    swal({ 
    title: "Leave this site?", 
    text: "If you click 'OK', you will be redirected to " + linkURL, 
    type: "warning", 
    showCancelButton: true 
    }, function() { 
    // Redirect the user 
    window.location.href = linkURL; 
    }); 
} 
</script> 

Ich versuche, eine Bestätigungstaste mit sweetalert zu erstellen. Ich habe versucht zu umleiten Route zu korrigieren, welche (http://localhost:8000/admin/category/13), aber die Laravel sagt:

MethodNotAllowedHttpException in RouteCollection.php Linie 219: ....

Mein Weg ist:

Route::delete('/admin/category/{id}', '[email protected]'); 

Was kann möglicherweise falsch sein oder dieses Problem beheben?

+0

verwenden Sie Laravel 5.1 –

+0

Ja, ich bin mit Laravel 5.1 ich auch ohne diesen JavaScript-Code hinzufügen haben die Route funktioniert und um die Kategorie löschen. –

Antwort

1

js:

$('.delete-photo').click(function(e) { 
    e.preventDefault(); // Prevent the href from redirecting directly 
    var linkURL = $(this).attr("action"); 
    warnBeforeRedirect(linkURL); 
}); 

function warnBeforeRedirect(linkURL) { 
    swal({ 
     title: "Are you sure?", 
     text: "You will not be able to recover this imaginary file!", 
     type: "warning", 
     showCancelButton: true, 
     confirmButtonColor: "#DD6B55", 
     confirmButtonText: "Yes, delete it!", 
     cancelButtonText: "No, cancel plx!", 
     closeOnConfirm: false, 
     closeOnCancel: false 
    }, 
    function(isConfirm) { 
     if (isConfirm) {       
      document.getElementById("myform").submit(); 
     } else { 
      swal("Cancelled", "Your imaginary file is safe :)", "error"); 
     } 
    } 
); 
} 

Meine Probleme waren: 1) einreichen muss durch die Form der Controller-Methode löschen, um aktiv. 2) Der previus Javascript nicht die csrf nahm hat Token