ich zusammen eine CRUD Anwendung mit Codeigniter gesetzt habe 3. Das Update-Formular Datenvalidierung wird eingerichtet, durch die Steuerung:Codeigniter CRUD App: Fehler einen Datensatz zu aktualisieren (versucht Eigenschaft von nicht-Objekt zu erhalten)
UPDATE Funktion:
public function update($customer_id) {
// data validation
$this->form_validation->set_rules('first_name', 'First name', 'required');
$this->form_validation->set_rules('last_name', 'Last name', 'required');
$this->form_validation->set_rules('email', 'Email address', 'required|valid_email');
$this->form_validation->set_error_delimiters('<p class="error">', '</p>');
if ($this->form_validation->run()) {
$data = [
// insert into these database table fields
'first_name' => $this->input->post('first_name'),
'last_name' => $this->input->post('last_name'),
'email' => $this->input->post('email')
];
$this->load->model('Customer');
if ($this->Customer->updateCustomer($customer_id, $data)) {
$this->session->set_flashdata('update-response','Customer successfully updated');
} else {
$this->session->set_flashdata('update-response','Failed to update customer');
}
redirect('home');
} else {
$data = [
'first_name' => $this->input->post('first_name'),
'last_name' => $this->input->post('last_name'),
'email' => $this->input->post('email'),
'id' => $customer_id
];
$this->load->view('update', array("customer" => $data));
}
}
Es tut durch die, wenn zu gehen, aber nicht durch das andere.
UPDATE Form:
<?php echo form_open("home/update/{$customer->id}"); ?>
<div class="form-group <?php if(form_error('first_name')) echo 'has-error';?>">
<?php echo form_input('first_name', set_value('first_name', $customer->first_name),[
'id' => 'first_name',
'class' => 'form-control'
]);
if(form_error('first_name')) echo '<span class="glyphicon glyphicon-remove"></span>';
echo form_error('first_name'); ?>
</div>
<div class="form-group">
<?php echo form_submit('submit', 'Save', 'class = "btn btn-success btn-block"'); ?>
</div>
<?php echo form_close(); ?>
Das UPDATE Modell ist:
public function getAllCustomers($customer_id) {
$query = $this->db->get_where('customers', array('id' => $customer_id));
if ($query->num_rows() > 0) {
return $query->row();
}
}
public function updateCustomer($customer_id, $data) {
return $this->db->where('id', $customer_id)->update('customers', $data);
}
Die UPDATE Ansicht:
<?php echo form_open("home/update/{$customer->id}"); ?>
Ther e ist dieses Problem mit einem Datensatz bearbeiten, ungültige Daten eingeben, dann die „Save-Button“ schlagen:
Severity: Notice
Message: Trying to get property of non-object
Filename: views/update.php
Ein solches Problem erscheint nur auf der Update-Formular. Was könnte die Ursache dafür sein?
http://www.codeigniter.com/user_guide/general/views.html#adding-dynamic- Data-to-the-view – user4419336