FuelPHP - दृश्य

ViewMVC एप्लिकेशन की प्रस्तुति परत है। यह एप्लिकेशन लॉजिक को प्रेजेंटेशन लॉजिक से अलग करता है। जब एक नियंत्रक को HTML, CSS या किसी अन्य सामग्री को उत्पन्न करने की आवश्यकता होती है, तो यह कार्य को दृश्य इंजन के लिए अग्रेषित करता है।

FuelPHP एक सरल और लचीला वर्ग प्रदान करता है, एक दृश्य इंजन के सभी आवश्यक सुविधाओं के साथ देखें। व्यू क्लास व्यू फाइल के प्रतिपादन का समर्थन करता है। देखें फ़ाइल एम्बेडेड PHP निर्देशों के साथ एक HTML पृष्ठ है। व्यू फ़ाइल के वेरिएबल्स को व्यू क्लास को PHP एरे के रूप में सेट करके व्यू फाइल में संदर्भित किया जा सकता है। आइए देखें वर्ग के कुछ महत्वपूर्ण तरीकों की जाँच करें।

फोर्ज

  • Purpose - एक नया दृश्य ऑब्जेक्ट बनाता है

  • Parameter - निम्नलिखित पैरामीटर हैं

    • $file - दृश्य फ़ोल्डर, ईंधन / एप्लिकेशन / विचारों के सापेक्ष दृश्य फ़ाइल का पथ

    • $data - मूल्यों की सरणी

    • $filter - मुख्य कॉन्फ़िगरेशन फ़ाइल में सेटिंग्स के लिए ऑटो एन्कोडिंग, चूक को सेट करता है

  • Returns - दृश्य का उदाहरण

उदाहरण के लिए,

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

auto_filter

  • Purpose - सेट करें कि डेटा को एनकोड करना है या नहीं

  • Parameter - निम्नलिखित पैरामीटर है

    • $filter - सच / झूठ

  • Returns - वर्तमान दृश्य वस्तु

उदाहरण के लिए,

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

set_filename

  • Purpose - व्यू फाइल को सेट या बदलने की अनुमति देता है।

  • Parameter - निम्नलिखित पैरामीटर है -

    • $file - फ़ाइल फ़ोल्डर, ईंधन / एप्लिकेशन / विचारों के सापेक्ष देखने के लिए पथ

  • Returns - वर्तमान दृश्य वस्तु

उदाहरण के लिए,

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

सेट

  • Purpose - एक या अधिक चर का मान सेट करें

  • Parameter - निम्नलिखित पैरामीटर हैं

    • $key - परिवर्तनीय नाम या मूल्यों की सरणी

    • $value - मान / अशक्त

    • $filter - एन्कोडिंग सेटिंग, सही / गलत

  • Returns - वर्तमान दृश्य वस्तु

उदाहरण के लिए,

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

set_global

set_global के समान है set, सिवाय इसके कि यह सभी विचारों पर लागू होता है और चर सभी विचारों द्वारा सुलभ हैं। यह एक स्थिर विधि है।

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

set_safe

  • Purpose - सुरक्षित एन्कोडिंग के साथ एक या अधिक चर का मान सेट करें।

  • Parameter - निम्नलिखित पैरामीटर हैं -

    • $key - परिवर्तनीय नाम या मूल्यों की सरणी

    • $value - मान / अशक्त

  • Returns - वर्तमान दृश्य वस्तु

उदाहरण के लिए,

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

प्राप्त

  • Purpose - एक या अधिक चरों का मान प्राप्त करें

  • Parameter - निम्नलिखित पैरामीटर हैं

    • $key - चर नाम

    • $default - यदि कुंजी नहीं मिली है तो डिफ़ॉल्ट मान लौटाया जाना चाहिए

  • Returns - इनपुट कुंजी का मान

उदाहरण के लिए,

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

प्रस्तुत करना

  • Purpose - स्थानीय और वैश्विक चर के साथ विलय करके दृश्य फ़ाइलों को स्ट्रिंग में रेंडर करें

  • Parameter - निम्नलिखित पैरामीटर हैं -

    • $file - दृश्य फ़ाइल नाम

  • Returns - स्ट्रिंग के रूप में प्रदान की गई फ़ाइल देखें

उदाहरण के लिए,

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

एक दृश्य बनाएँ

विचारों को समझने के लिए, हम एक्शन विधि, नियंत्रक के एक्शन_ को संशोधित करते हैं , कंट्रोलर_इम्प्लॉई

employee.php

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

अब फ्यूल / एप / व्यू में स्थित व्यू डायरेक्टरी में एक फोल्डर कर्मचारी बनाएं । फिर, कर्मचारी फ़ोल्डर के अंदर एक फ़ाइल show.php बनाएँ और निम्न कोड जोड़ें।

show.php

<h3> My first view </h3>

अब, url http: // localhost: 8080 / कर्मचारी / शो का अनुरोध करें और यह निम्नलिखित परिणाम तैयार करता है।

देखने के लिए डेटा पास करना

हम पहले चर्चा किए गए तरीकों के अनुसार दृश्य विधियों का उपयोग करके डेटा को पास कर सकते हैं। निम्नलिखित एक सरल उदाहरण है।

employee.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); 
   } 
}

अब, परिवर्तनों को जोड़ें view फ़ाइल।

show.php

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

URL का अनुरोध करने के बाद, यह नाम और कार्य को निम्नानुसार प्रदर्शित करेगा -

फ़िल्टर देखें

दृश्य आउटपुट एन्कोडिंग का उपयोग करते हैं जो आप चाहते हैं। यदि आप अनफ़िल्टर्ड डेटा पास करना चाहते हैं, तो हम सेट विधि का उपयोग कर सकते हैं।

employee.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; 
   } 
}

URL का अनुरोध करने के बाद, यह निम्नानुसार कार्य शैली को जोर शैली में प्रदर्शित करेगा।

नेस्टेड दृश्य

FuelPHP नेस्टेड विचारों का समर्थन करता है। नेस्टेड विचारों में, एक दृश्य में एक या अधिक दृश्य हो सकते हैं। विचारों को दूसरे दृश्य में सेट करने के लिए, हम रेंडर विधि का उपयोग निम्नानुसार कर सकते हैं।

employee.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(); 
   } 
}

ईंधन / ऐप्स / विचारों / layout.php

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

ईंधन / ऐप्स / विचारों / head.php

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

ईंधन / ऐप्स / विचारों / कर्मचारी / show.php

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

URL, http: // localhost: 8080 / कर्मचारी / नेस्टव्यू और स्रोत दृश्य की जांच करने का अनुरोध करने के बाद , यह निम्नलिखित कोड देता है।

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

टेम्पलेट नियंत्रक

FuelPHP अंतर्निहित लेआउट अवधारणा के साथ एक नियंत्रक, नियंत्रक_Template प्रदान करता है। लेआउट अवधारणा का उपयोग करके किया जाता हैbefore() तथा after()नियंत्रक की विधि। टेम्प्लेट कंट्रोलर का उपयोग करने के लिए, हमें कंट्रोलर को नियंत्रक की बजाय कंट्रोलरटेम्पलेट का उपयोग करना होगा। उपयोग करने के बाद () / इससे पहले () विधि, हमें अभिभावक को कॉल करने की आवश्यकता है :: पहले और माता-पिता :: के बाद, अन्यथा, टेम्पलेट टूट जाता है।

<?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

यह फ्यूल में एक डिफॉल्ट टेम्प्लेट फाइल है। जेएसएम, सीएसएस, एचटीएमएल को कॉल करने के लिए टेम्प्लेट फ़ाइल का उपयोग किया जाता है, और व्यू भाग को कॉल किया जाता है। यह वहां स्थित हैfuel/app/views/। टेम्प्लेट का उपयोग हेडर, फुटर, साइडबार इत्यादि के साथ लेआउट में आपके दृश्य को लपेटने के लिए किया जाता है। हम एक्शन विधि में $ टेम्प्लेट चर का उपयोग करके डिफ़ॉल्ट टेम्प्लेट को बदल सकते हैं।

ईंधन / ऐप्स / वर्गों / नियंत्रक / 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'); 
      } 
   }

ईंधन / ऐप्स / विचारों / 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>

ईंधन / ऐप्स / विचारों / परीक्षण / index.php

<h3>My Test page</h3>

अब, URL http: // localhost: 8080 / परीक्षण का अनुरोध करें और यह निम्नलिखित परिणाम उत्पन्न करता है।

परिणाम

<!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>

देखें पृष्ठ उत्पन्न करें

आप फ्यूल के ऑयल कंसोल का उपयोग करके एक व्यू पेज जेनरेट कर सकते हैं। निम्नलिखित मूल सिंटैक्स है।

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

घर और लॉगिन पृष्ठों के साथ एक व्यवस्थापक नियंत्रक उत्पन्न करने के लिए, निम्न कमांड का उपयोग करें।

oil g controller admin home login

परिणाम

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