ホームページ >バックエンド開発 >PHPチュートリアル >CodeIgniter によるサードパーティ ライブラリ third_party の使用状況分析

CodeIgniter によるサードパーティ ライブラリ third_party の使用状況分析

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBオリジナル
2016-07-29 09:05:34967ブラウズ

この記事では、CodeIgniter を利用したサードパーティ クラス ライブラリ third_party の使用法を分析します。参考のために皆さんと共有してください。詳細は次のとおりです。

third_party は、システムに導入されたサードパーティのクラス ライブラリを保存するために使用されます。クラス ライブラリは通常、より豊富な機能を提供し、対応する学習コストが高くなります。システム内で使用できる機能は限られているため、他の人がシステム内で使用する際に注意する必要があるのは、クラス ライブラリを導入する際に適切なカプセル化を行うことをお勧めします。メソッドを使用するため、特定の実装に注意を払うことができません。 CI 統合 Twig テンプレートを例に挙げます。

まず、Twig クラス ライブラリをダウンロードして third_party に配置し、それをライブラリにカプセル化する必要があります。例は次のとおりです。

<&#63;php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
require APPPATH.'third_party/Twig/Autoloader.php';
/**
 * Twig模版引擎
 *
 */
class Twig
{
  public $twig;
  public $config;
  private $data = array();
  /**
   * 读取配置文件twig.php并初始化设置
   * 
   */
  public function __construct($config)
  {
    $config_default = array(
      'cache_dir' => false,
      'debug' => false,
      'auto_reload' => true,
      'extension' => '.tpl',
    );
    $this->config = array_merge($config_default, $config);
    Twig_Autoloader::register ();
    $loader = new Twig_Loader_Filesystem ($this->config['template_dir']);
    $this->twig = new Twig_Environment ($loader, array (
        'cache' => $this->config['cache_dir'],
        'debug' => $this->config['debug'],
        'auto_reload' => $this->config['auto_reload'], 
    ) );
    $CI = & get_instance ();
    $CI->load->helper(array('url'));
    $this->twig->addFunction(new Twig_SimpleFunction('site_url', 'site_url'));
    $this->twig->addFunction(new Twig_SimpleFunction('base_url', 'base_url'));
  }
  /**
   * 给变量赋值
   * 
   * @param string|array $var
   * @param string $value
   */
  public function assign($var, $value = NULL)
  {
    if(is_array($var)) {
      foreach($val as $key => $val) {
        $this->data[$key] = $val;
      }
    } else {
      $this->data[$var] = $value;
    }
  }
  /**
   * 模版渲染
   * 
   * @param string $template 模板名
   * @param array $data 变量数组
   * @param string $return true返回 false直接输出页面
   * @return string
   */
  public function render($template, $data = array(), $return = FALSE)
  {
    $template = $this->twig->loadTemplate ( $this->getTemplateName($template) );
    $data = array_merge($this->data, $data);
    if ($return === TRUE) {
      return $template->render ( $data );
    } else {
      return $template->display ( $data );
    }
  }
  /**
   * 获取模版名
   * 
   * @param string $template
   */
  public function getTemplateName($template)
  {
    $default_ext_len = strlen($this->config['extension']);
    if(substr($template, -$default_ext_len) != $this->config['extension']) {
      $template .= $this->config['extension'];
    }
    return $template;
  }
  /**
   * 字符串渲染
   * 
   * @param string $string 需要渲染的字符串
   * @param array $data 变量数组
   * @param string $return true返回 false直接输出页面
   * @return string
   */
  public function parse($string, $data = array(), $return = FALSE)
  {
    $string = $this->twig->loadTemplate ( $string );
    $data = array_merge($this->data, $data);
    if ($return === TRUE) {
      return $string->render ( $data );
    } else {
      return $string->display ( $data );
    }
  }
}
/* End of file Twig.php */
/* Location: ./application/libraries/Twig.php */

テンプレートの操作には通常、いくつかの構成情報が含まれており、これはここで行われます。 config Configuration の下の twig.php を介して、CI ロード ライブラリを通じてロードされるときに、クラス名と同じ名前の設定ファイルが存在する場合、パラメーターは配列の形式でクラスのコンストラクターに自動的に渡されます。

<?php
// 默认扩展名
$config['extension'] = ".tpl";
// 默认模版路劲
$config['template_dir'] = APPPATH . "views/";
// 缓存目录
$config['cache_dir'] = APPPATH . "cache/twig/";
// 是否开启调试模式
$config['debug'] = false;
// 自动刷新
$config['auto_reload'] = true;
/* End of file twig.php */
/* Location: ./application/config/twig.php */

base_url site_url やその他の関数をテンプレートに読み込むには、クラスが CI に依存しているため、サービス内で一度カプセル化するか、いくつかのカスタム関数を追加するなど、分離した方がよい場合があります。 ., 他の場所や他のシステムがこのクラスを再利用できるようにするため、非常に便利です。

さらに codeigniter 関連のコンテンツに興味のある読者は、このサイトの特別トピック「codeigniter チュートリアルの概要」と「CI (CodeIgniter) フレームワークの高度なチュートリアル」をチェックしてください

この記事で説明されている内容が理解できることを願っていますCodeIgniter フレームワークに基づいた PHP プログラムの設計に役立ちます。

上記は、CodeIgniter によるサードパーティ クラス ライブラリ third_party の使用状況分析を内容も含めて紹介しています。PHP チュートリアルに興味のある友人の参考になれば幸いです。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。