[Vue 警告]:渲染时出错:“TypeError:无法读取未定义的属性‘id’”
2018-02-04
7180
我正在使用 Laravel 和 VueJS 构建 CRUD。当我提交创建表单时,我收到此消息错误:[Vue warn]:渲染时出错:“TypeError:无法读取未定义的属性‘id’”
这里是我的 createUser 方法:
export default {
data(){
return {
user: {
firstname: '',
lastname: '',
email: '',
password: ''
},
errors: [],
users: [],
update_user: {}
}
},
mounted(){
this.readUsers();
},
methods: {
createUser(){
axios.post('user', {
firstname: this.user.firstname,
lastname: this.user.lastname,
email: this.user.email,
password: this.user.password
}).then(response => {
this.reset();
if (response.data.message == "Error"){
this.errors.push("L'utilisateur que vous tentez d'ajouter existe déjà!")
}else{
this.users.push(response.data.user);
}
})
},
readUsers(){
axios.get('user')
.then(response => {
this.users = response.data.users;
});
},
}
}
这里是我显示数据库中所有用户的表格。显示用户工作正常。
<table class="table table-bordered table-striped table-responsive" v-if="users.length > 0">
<tbody>
<tr>
<th>#</th>
<th>Nom</th>
<th>Prénom</th>
<th>Adresse e-mail</th>
<th>Action</th>
</tr>
<tr v-for="(user, index) in users">
<td>{{ user.id }}</td>
<td>{{ user.lastname }}</td>
<td>{{ user.firstname }}</td>
<td>{{ user.email }}</td>
<td>
<button @click="initUpdate(index)" class="btn btn-success btn-xs">Éditer</button>
<button @click="deleteUser(index)" class="btn btn-danger btn-xs">Supprimer</button>
</td>
</tr>
</tbody>
</table>
我的 Laravel 用户模型在这里:
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use Notifiable;
protected $fillable = [
'id',
'firstname',
'lastname',
'email',
'password'
];
protected $hidden = [
'password', 'remember_token',
];
}
最后是我的 UserController 方法:
public function store(Request $request)
{
$this->validate($request, [
'firstname' => 'required',
'lastname' => 'required',
'email' => 'required',
'password' => 'required'
]);
$user = User::create([
'firstname' => request('firstname'),
'lastname' => request('lastname'),
'email' => request('email'),
'password' => Hash::make(request('password'))
]);
return response()->json([
'user' => $user,
'message' => 'Success'
], 200);
}
1个回答
create() 方法返回模型。因此,您需要稍微转换一下用户集合,
public function store(Request $request)
{
$this->validate($request, [
'firstname' => 'required',
'lastname' => 'required',
'email' => 'required',
'password' => 'required'
]);
$user = User::create([
'firstname' => request('firstname'),
'lastname' => request('lastname'),
'email' => request('email'),
'password' => Hash::make(request('password'))
]);
return response()->json([
'user' => [
'id'=>$user->id,
'firstname'=>$user->firstname,
'lastname'=>$user->lastname,
'email'=>$user->email
],
'message' => 'Success'
], 200);
}
Leo
2018-02-04