Je několik věcí, které by se daly objasnit:
model
je entita, která přetrvává v databázi. Ve vašem případě:Členstvícontroller
má na starosti načtení modelu a jeho předání do pohledu, který má být zobrazenview
pouze by měl mít značku html, žádné funkce, žádnou logiku.
Databáze
Za předpokladu, že vaše databáze má níže uvedenou strukturu.
+---------------+-----------+------------+--------------------+
| id_membership | username | name | email |
+---------------+-----------+------------+--------------------+
| 1 | Marishka | marishkapv | [email protected] |
| 2 | johndoe | John | [email protected] |
| 3 | dennisv | Dennis | [email protected] |
+---------------+-----------+------------+--------------------+
Model
Můžete si vytvořit svůj model class Membership extends CI_Model
na /application/models/membership.php
soubor.
class Membership extends CI_Model {
function __construct()
{
parent::__construct();
}
function member_here()
{
$this->db->select('');
$this->db->from('membership');
$this->db->where('username',$this->input->post('username'));
$q = $this->db->get('');
if($q->num_rows() > 0)
{
$data = array();
foreach($q->result() as $row)
{
$data=$row;
}
return $data;
}
}
}
Ovladač
Předpokládejme, že máte přihlašovací stránku na adrese example.com/index.php/login
, měl by být umístěn na /application/controllers/login.php
jak je uvedeno níže:
class Login extends CI_Controller
{
function __construct()
{
parent::__construct();
}
public function index()
{
$this->load->view('login_view');
}
public function result()
{
$this->load->model('membership');
$data['member'] = $this->membership->member_here();
$this->load->view('result_view', $data);
}
}
Vypadá to, že modely jsou načteny, vyvolá tyto dva řádky:
//Load the model in make use of its functions
$this->load->model('membership');
//load the row whit the given username
//the result is assigned to array with the key "member", in the view you access this
//value with $member var
$data['member'] = $this->membership->member_here();
Zobrazení
Jak jste si všimli v kódu ovladače, existují dva soubory zobrazení, login_view
a result_view
. První zobrazí html formulář, kam můžete zadat uživatelské jméno, abyste spustili výběrový dotaz. result_view
zobrazit informace o členu dle zvoleného členství
login_view.php
<html>
<head></head>
<body>
<form action="login/result" method="post">
Type your username: <input type="text" name="username" />
<input type="submit" value="Load from database" />
</form>
</body>
</html>
result_view.php
<h4>Details:</h4>
<p>
Id: <?=$member->id_membership?> <br />
Username: <?=$member->username?> <br />
Email: <?=$member->email?>
</p>