FuelPHP - widoki

Viewto warstwa prezentacji aplikacji MVC. Oddziela logikę aplikacji od logiki prezentacji. Gdy kontroler musi wygenerować HTML, CSS lub inną zawartość, przekazuje zadanie do silnika widoku.

FuelPHP zapewnia prostą i elastyczną klasę View z wszystkimi niezbędnymi funkcjami silnika widoku. Klasa View obsługuje renderowanie pliku widoku. Plik widoku to strona HTML z osadzonymi instrukcjami PHP. Zmienne pliku widoku można ustawić za pomocą klasy View jako tablicy PHP i odwoływać się do pliku widoku za pomocą klucza tablicy. Sprawdźmy kilka ważnych metod klasy View.

fałszować

  • Purpose - Tworzy nowy obiekt widoku

  • Parameter - Poniżej przedstawiono parametry

    • $file - Ścieżka pliku widoku względem folderu widoków, paliwo / aplikacja / widoki

    • $data - Tablica wartości

    • $filter - Ustawia automatyczne kodowanie, domyślnie są to ustawienia w głównym pliku konfiguracyjnym

  • Returns - Wystąpienie widoku

Na przykład,

$view = View::forge ('path/to/view', array( 
   'title' => "Show employee, 
   'employees' => $employees, 
));

auto_filter

  • Purpose - Określ, czy kodować dane, czy nie

  • Parameter - Poniżej znajduje się parametr

    • $filter - prawda / fałsz

  • Returns - Bieżący widok obiektu

Na przykład,

$view->auto_filter(); 
$view = $view->auto_filter(false);

set_filename

  • Purpose - Pozwala ustawić lub zmienić plik widoku.

  • Parameter - Poniżej znajduje się parametr -

    • $file - Ścieżka do przeglądania pliku względem folderu widoków, paliwa / aplikacji / widoków

  • Returns - Bieżący obiekt widoku

Na przykład,

$view = new View();
$view>set_filename('path/to/view');

zestaw

  • Purpose - Ustaw wartość jednej lub więcej zmiennych

  • Parameter - Poniżej przedstawiono parametry

    • $key - Nazwa zmiennej lub tablica wartości

    • $value - Wartość / null

    • $filter - Ustawienie kodowania, prawda / fałsz

  • Returns - Bieżący widok obiektu

Na przykład,

$view = new View(); 
$view->set(array('name' => 'Jon'));

set_global

set_global jest podobny do set, z wyjątkiem tego, że dotyczy wszystkich widoków, a zmienne są dostępne we wszystkich widokach. To jest metoda statyczna.

View::set_global('name', 'Jon', false);

set_safe

  • Purpose - Ustaw wartość co najmniej jednej zmiennej z włączonym bezpiecznym kodowaniem.

  • Parameter - Poniżej przedstawiono parametry -

    • $key - Nazwa zmiennej lub tablica wartości

    • $value - Wartość / null

  • Returns - Bieżący widok obiektu

Na przykład,

$view = new View(); 
$view->set_safe(array('name' => 'Jon'), null);

otrzymać

  • Purpose - Uzyskaj wartość jednej lub więcej zmiennych

  • Parameter - Poniżej przedstawiono parametry

    • $key - Nazwa zmiennej

    • $default - Wartość domyślna, która ma zostać zwrócona, jeśli klucz nie zostanie znaleziony

  • Returns - Wartość klucza wejściowego

Na przykład,

$view = new View(); 
$name = $view>get('name');  // name = 'Jon'

renderowanie

  • Purpose - Renderuj pliki widoku w łańcuchy, łącząc je ze zmiennymi lokalnymi i globalnymi

  • Parameter - Poniżej przedstawiono parametry -

    • $file - nazwa pliku widoku

  • Returns - Wyrenderowany plik widoku jako ciąg

Na przykład,

$html = View::forge()->render('/path/to/view');

Utwórz widok

Aby zrozumieć widoki, zmodyfikujmy metodę akcji, action_show kontrolera, Controller_Employee .

pracownik.php

<?php  
   class Controller_Employee extends Controller { 
      public function action_show() {
         return View::forge('employee/show'); 
      } 
   }

Teraz utwórz folder pracownika w katalogu views, znajdującym się pod adresem fuel / app / views . Następnie utwórz plik show.php w folderze pracownika i dodaj następujący kod.

show.php

<h3> My first view </h3>

Teraz poproś o adres URL http: // localhost: 8080 / worker / show, a otrzymasz następujący wynik.

Przekazywanie danych do widoku

Możemy przekazywać dane do widoków za pomocą metod View, jak omówiono wcześniej. Oto prosty przykład.

pracownik.php

class Controller_Employee extends Controller { 
   public function action_show() { 
      $data = array(); //stores variables going to views 
      $data['name'] = ‘Jon’; 
      $data[‘job’] = ‘Designer’;  
      
      //assign the view to browser output 
      return View::forge('employee/show', $data); 
   } 
}

Teraz dodaj zmiany w view plik.

show.php

<html> 
   <body> 
      Hello, <?php echo $name; ?>. 
      Your job is, <?php echo $job; ?>. 
   </body> 
</html>

Po zażądaniu adresu URL wyświetli nazwę i zadanie w następujący sposób -

Wyświetl filtr

Widoki używają kodowania wyjściowego, aby przekazać wszystko, co chcesz. Jeśli chcesz przekazać niefiltrowane dane, możemy skorzystać z metody set.

pracownik.php

class Controller_Employee extends Controller { 
   public function action_show() { 
      $view = \View::forge('employee/show'); 
      $view->set('name', 'Jon', true); 
      $view->set('job', '<em>Designer</em>', false); 
      return $view; 
   } 
}

Po zażądaniu adresu URL szczegóły zadania zostaną wyświetlone z wyróżnieniem w następujący sposób.

Zagnieżdżone widoki

FuelPHP obsługuje zagnieżdżone widoki. W widokach zagnieżdżonych widok może zawierać jeden lub więcej widoków. Aby ustawić widoki w innym widoku, możemy użyć metody renderowania w następujący sposób.

pracownik.php

class Controller_Employee extends Controller { 
   public function action_nestedview() { 
      
      //assign variables 
      $data = array(); 
      $data['title'] = 'Home';  
      $data['name'] = 'Jon'; 
      $data['job'] = 'Designer';  
      $views = array(); 
      $views['head'] = View::forge('head', $data)->render(); 
      $views['content'] = View::forge('employee/show', $data)->render();  
      return View::forge('layout', $views, false)->render(); 
   } 
}

fuel / app / views / layout.php

<html> 
   <head> 
      <?php echo $head; ?> 
   </head> 
   
   <body> 
      <?php echo $content; ?> 
   </body> 
</html>

fuel / app / views / head.php

<title>
   <?php echo $title; ?>
</title>

paliwo / aplikacja / widoki / pracownik / show.php

Hello, <?php echo $name; ?>. 
Your job is, <?php echo $job; ?>.

Po zażądaniu adresu URL, http: // localhost: 8080 / worker / nestedview i sprawdzeniu widoku źródła, daje następujący kod.

<html> 
   <head> 
      <title>Home</title> 
   </head> 
   
   <body> 
      Hello, Jon. 
      Your job is, Designer. 
   </body> 
</html>

Kontroler szablonów

FuelPHP dostarcza kontroler Controller_Template z wbudowaną koncepcją układu. Koncepcja układu jest wykonywana za pomocąbefore() i after()metoda kontrolera. Aby użyć kontrolera szablonu, musimy rozszerzyć kontroler za pomocą Controller_Template zamiast Controller. Używając metody after () / before (), musimy wywołać parent :: before i parent :: after, w przeciwnym razie szablon się zepsuje.

<?php 
   class Controller_Test extends Controller_Template { 
      public function before() { 
         parent::before(); 
         // do stuff 
      } 
        
      public function after($response) { 
         $response = parent::after($response); 
         
         // do stuff 
         return $response; 
      } 
   }

template.php

Jest to domyślny plik szablonu w programie Fuel. Plik szablonu służy do wywoływania podrzędnych elementów JS, CSS, HTML i wywołań widoku. Znajduje się nafuel/app/views/. Szablony służą do zawijania widoku w układzie z nagłówkiem, stopką, paskiem bocznym itp. Możemy zmienić domyślny szablon za pomocą zmiennej $ template w metodzie akcji w następujący sposób.

paliwo / aplikacja / classes / controller / test.php

<?php  
   class Controller_Test extends Controller_Template { 
      public $template = 'template_test'; 
      public function action_index() { 
         $this->template->title = 'Example Page'; 
         $this->template->content = View::forge('test/index'); 
      } 
   }

paliwo / app / views / template_test.php

<!DOCTYPE html> 
<html> 
   <head> 
      <meta charset = "utf-8"> 
      <title><?php echo $title; ?></title> 
      <?php echo Asset::css('bootstrap.css'); ?> 
   </head> 

   <body> 
      <div> 
         <?php echo $content; ?>
      </div> 
   </body> 
</html>

fuel / app / views / test / index.php

<h3>My Test page</h3>

Teraz poproś o adres URL http: // localhost: 8080 / test, a otrzymasz następujący wynik.

Wynik

<!DOCTYPE html> 
<html> 
   <head> 
      <meta charset = "utf-8"> 
      <title>Example Page</title> 
      <link type = "text/css" rel = "stylesheet" 
         href = "http://localhost:8080/assets/css/bootstrap.css?1464964766" />
   </head> 
   
   <body> 
      <div> 
         <h3>My Test page</h3> 
      </div> 
   </body> 
</html>

Wygeneruj stronę widoku

Możesz wygenerować stronę widoku za pomocą konsoli Fuel's Oil. Poniżej znajduje się podstawowa składnia.

oil g controller <controller-name> <page1> <page2> ..

Aby wygenerować kontroler administratora ze stroną główną i stroną logowania, użyj następującego polecenia.

oil g controller admin home login

Wynik

Creating view: /path/to/app/fuel/app/views/admin/home.php 
Creating view: /path/to/app/fuel/app/views/admin/login.php 
Creating controller: /path/to/app/fuel/app/classes/controller/admin.php