CodeIgniter: создать новый помощник? - PullRequest
173 голосов
/ 30 апреля 2009

Мне нужно по-разному зацикливать множество массивов и отображать их на странице. Массивы генерируются классом модуля. Я знаю, что лучше не включать функции в «представления», и я хочу знать, куда вставить файл функций.

Я знаю, что могу «расширять» помощников, но я не хочу расширять помощника. Я хочу создать помощника с помощью моих функций цикла. Давайте назовем его loops_helper.php

Ответы [ 7 ]

365 голосов
/ 30 апреля 2009

Помощник CodeIgniter - это файл PHP с несколькими функциями. Это не класс

Создайте файл и вставьте в него следующий код.

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

if ( ! function_exists('test_method'))
{
    function test_method($var = '')
    {
        return $var;
    }   
}

Сохраните это в application / helpers / . Мы назовем это "new_helper.php"

Первая строка существует, чтобы убедиться, что файл не может быть включен и запущен за пределами области действия CodeIgniter. Все, что после этого говорит само за себя.

Использование помощника


Это может быть ваш контроллер , модель или представление (не желательно)

$this->load->helper('new_helper');

echo test_method('Hello World');

Если вы используете этот помощник во многих местах, вы можете загрузить его автоматически, добавив его в файл конфигурации автозагрузки, т.е. <your-web-app>\application\config\autoload.php.

$autoload['helper'] = array('new_helper');

-Mathew

78 голосов
/ 15 мая 2009

Некоторый код, который позволяет вам использовать экземпляр CI внутри помощника:

function yourHelperFunction(){
    $ci=& get_instance();
    $ci->load->database(); 

    $sql = "select * from table"; 
    $query = $ci->db->query($sql);
    $row = $query->result();
}
17 голосов
/ 21 мая 2013

Ну у меня работает только добавление текста "_helper" после в php файл вроде:

Codeiginiter Helpers

И для автоматической загрузки помощника в папку aplication -> file autoload.php добавить в массив имя помощника без "_helper", например:

$ autoload ['helper'] = array ('comunes');

И с этим я могу использовать все функции помощника

11 голосов
/ 30 апреля 2009

Чтобы создать нового помощника, вы можете следовать инструкциям от Pixel Developer , но я советую не создавать помощника только для логики, требуемой определенной частью конкретного приложения. Вместо этого используйте эту логику в контроллере, чтобы установить для массивов их окончательные предполагаемые значения. Получив это, вы передаете их в представление с помощью Template Parser Class и (надеюсь) вы можете сохранить представление чистым от всего, что выглядит как PHP, используя простые переменные или пары переменных тегов вместо echos и foreachs , то есть:

{blog_entries}
<h5>{title}</h5>
<p>{body}</p>
{/blog_entries}

вместо

<?php foreach ($blog_entries as $blog_entry): ?>
<h5><?php echo $blog_entry['title']; ?></h5>
<p><?php echo $blog_entry['body']; ?></p>
<?php endforeach; ?>

Еще одним преимуществом этого подхода является то, что вам не нужно беспокоиться о добавлении экземпляра CI, как если бы вы использовали пользовательские помощники для выполнения всей работы.

3 голосов
/ 02 мая 2016

Чтобы извлечь элемент из вашего конфигурационного файла, используйте следующую функцию:

$this->config->item('item name'); Где имя элемента - индекс массива $ config, который вы хотите получить. Например, чтобы выбрать язык, вы должны сделать следующее:

$lang = $this->config->item('language'); Функция возвращает FALSE (логическое значение), если элемент, который вы пытаетесь получить, не существует.

Если вы используете второй параметр функции $ this-> config-> load для назначения элементов конфигурации определенному индексу, вы можете получить его, указав имя индекса во втором параметре $ this- > config-> item () функция. Пример:

// Загружает файл конфигурации с именем blog_settings.php и назначает его для индекса с именем "blog_settings"

$this->config->load('blog_settings', TRUE);

// Получить элемент конфигурации с именем site_name, содержащийся в массиве blog_settings

$site_name = $this->config->item('site_name', 'blog_settings');

// Альтернативный способ указать тот же элемент:

$blog_config = $this->config->item('blog_settings');

$ site_name = $ blog_config ['site_name'];

3 голосов
/ 17 апреля 2015

Просто определите помощника в каталоге помощника приложения затем вызовите из вашего контроллера просто имя функции, как

helper name = new_helper.php
function test_method($data){
 return $data
}   

в контроллере загрузить помощник

$this->load->new_helper();
$result =  test_method('Hello world!');
if($result){
 echo $result
}

вывод будет

Hello World!
3 голосов
/ 07 ноября 2012

Создайте файл с именем вашего помощника в / application / helpers и добавьте его в файл конфигурации автозагрузки / загрузите его вручную.

например. поместите файл с именем user_helper.php в / application / helpers с таким содержимым:

<code><?php
  function pre($var)
  {
    echo '<pre>';
    if(is_array($var)) {
      print_r($var);
    } else {
      var_dump($var);
    }
    echo '
'; } ?>

Теперь вы можете загрузить помощника через $this->load->helper(‘user’); или добавить его в application / config / autoload.php config.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...