0
這是我的形式方法與laraval用於PUT方法
<form class="form-horizontal alert alert-info" id="editForm" ng-submit="updateComment(currentComment)" hidden>
<h3 class="text-center">Update Comment Details</h3>
<div class="form-group">
<label for="Name">Author Name:</label>
<input type="text" class="form-control" ng-model="currentComment.author" value="{{currentComment.author}}">
</div>
<div class="form-group">
<label for="text">Comment Text:</label>
<input type="text" class="form-control" ng-model="currentComment.text" value="{{currentComment.text}}">
</div>
<input name="_method" type="hidden" value="PUT">
<div class="form-group">
<button class="btn btn-warning" ng-disabled="" ng-click="">Update</button>
<button class="btn btn-warning" ng-disabled="" ng-click="HideEditForm()">Cancel</button>
</div>
</form>
這是我的服務
angular.module('commentService', [])
.factory('Comment', function($http) {
return {
get : function() {
return $http.get('api/comments');
},
show : function(id) {
return $http.get('api/comments/' + id);
},
save : function(commentData) {
return $http({
method: 'POST',
url: 'api/comments',
headers: { 'Content-Type' : 'application/x-www-form-urlencoded' },
data: $.param(commentData)
});
},
update : function(commentData) {
return $http({
method: 'PUT',
url: 'api/comments',
headers: { 'Content-Type' : 'application/x-www-form-urlencoded' },
data: $.param(commentData)
});
},
destroy : function(id) {
return $http.delete('api/comments/' + id);
}
}
});
,這是我的角的js控制器
angular.module('mainCtrl', ['datatables'])
.controller('mainController', function($scope, $http, Comment) {
// object to hold all the data for the new comment form
$scope.commentData = {};
// loading variable to show the spinning loading icon
$scope.loading = true;
// get all the comments first and bind it to the $scope.comments object
Comment.get()
.success(function(data) {
$scope.comments = data;
$scope.loading = false;
});
// function to handle editing the form
$scope.currentComment = {};
$scope.editForm = function(id){
Comment.show(id).success(function(data){
$scope.currentComment = data;
$('#empForm').slideUp();
$('#editForm').slideToggle();
});
};
$scope.updateComment = function(commentData){
Comment.update(commentData).success(function(data){
});
};
//hide edit form
$scope.HideEditForm = function(){
$('#editForm').slideToggle();
};
// function to handle submitting the form
$scope.submitComment = function() {
$scope.loading = true;
// save the comment. pass in comment data from the form
Comment.save($scope.commentData)
.success(function(data) {
$scope.commentData = {};
// if successful, we'll need to refresh the comment list
Comment.get()
.success(function(getData) {
$scope.comments = getData;
$scope.loading = false;
});
})
.error(function(data) {
console.log(data);
});
};
// function to handle deleting a comment
$scope.deleteComment = function(id) {
$scope.loading = true;
Comment.destroy(id)
.success(function(data) {
// if successful, we'll need to refresh the comment list
Comment.get()
.success(function(getData) {
$scope.comments = getData;
$scope.loading = false;
});
});
};
});
和這是我的控制器
<?php
class CommentController extends \BaseController {
/**
* Send back all comments as JSON
*
* @return Response
*/
public function index()
{
return Response::json(Comment::get());
}
/**
* Store a newly created resource in storage.
*
* @return Response
*/
public function store()
{
Comment::create(array(
'author' => Input::get('author'),
'text' => Input::get('text')
));
return Response::json(array('success' => true));
}
/**
* update a resource in storage.
*
* @return Response
*/
public function update()
{
Comment::where('id', Input::get('author'))->update(['author'=>Input::get('author'), 'text'=>Input::get('text')]);
return Response::json(array('success' => true));
}
/**
* Return the specified resource using JSON
*
* @param int $id
* @return Response
*/
public function show($id)
{
return Response::json(Comment::find($id));
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return Response
*/
public function destroy($id)
{
Comment::destroy($id);
return Response::json(array('success' => true));
}
}
所有的方法工作,除了put方法我是新來的角請幫我的問題在此先感謝
是的,我知道我可以使用後,但我想使用REST API約定... – hu7sy
則必須使用X WWW的形式,進行了urlencoded,而不是形式 - 數據,那個ê其他答案 –
我使用它的兄弟你可以看到我的更新功能在服務 – hu7sy