创建项目后直接删除


Delete item directly after creating

我已经创建了一个可以存储项目的页面。但是当我尝试添加一个项目并在创建后立即删除它时,id是未定义的。当我插入一个项目后刷新页面,我可以删除该项目没有任何问题。

我需要找到一种方法,在我把洞的东西推到我的json数组之前,我可以从数据库中获得项目id。

<form ng-submit="submit('Bedrijf')">
        <input type="text" ng-model="title" placeholder="Add item" />
        <input type="text" ng-model="searchText" placeholder="Search for item"/>
        <button type="submit">Submit</button>
    </form>
    <br/>
    <ul>
        <li ng-repeat="project in projects | orderBy:'id':true | filter:statusFilterOpen | filter:searchText | limitTo: 10">
            <a href="projects/[[project.id]]">[[project.title]]</a>
            <a class="btn" ng-click="remove(project.id)">Delete</a>
        </li>
    </ul>

project.controller("PrjctCtrl", function($scope, $http, $timeout) {
$http.get('js/projects.json').
    success(function(data, status, headers, config) {
        $scope.projects = data;
        $scope.statusFilterOpen = function (project) {
            return project.status < 100;
        };
        $scope.statusFilterClosed = function (project) {
            return project.status === 100;
        };

    }).
    error(function(data, status, headers, config) {
        // log error
    });

$scope.submit = function($company) {
    data = {
        title: $scope.title,
        company: $company,
        status: 0
    };
    $http.post('add-projects', data).success(function(post) {
        console.log(post)
        $scope.projects.push(post);
    });
};
$scope.remove = function(id) {
    $http.post('delete-project/' + id).success(function(test) {
        $scope.projects.splice($scope.projects.indexOf(id),1);
        if(popupService.showPopup('Really delete this?')){
            movie.$delete(function(){
                $window.location.href='';
            });
        }
    });

}

});

我和laravel一起在数据库中存储所有东西。

public function store()
{
    $content = Input::json()->all();
    DB::table('projects')->insert(
        $array = array(
            'title' => $content['title'],
            'active' => '1',
            'company' => 'Bedrijf',
            'id' => 'test'
        )
    );
    return $array;
}
    public function destroy($id) {
    $project = Projects::find($id);
    $project->delete();
    return 'ok';
}

看看你的代码,delete语句的格式和其他语句不一样。

<a href="projects/[[project.id]]">[[project.title]]</a>
<a class="btn" ng-click="remove(project.id)">Delete</a>

应该是:

<a href="projects/[[project.id]]">[[project.title]]</a>
<a class="btn" ng-click="remove([[project.id]])">Delete</a>