1
0
mirror of https://github.com/php/doc-ru.git synced 2026-04-27 01:08:05 +02:00
Files
archived-doc-ru/reference/yaf/yaf-loader.xml
T
2024-06-14 17:02:33 +01:00

301 lines
11 KiB
XML

<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: ecaa2146429a7f88de40dfce14718afc896b74c5 Maintainer: sergey Status: ready -->
<!-- Reviewed: no -->
<reference xml:id="class.yaf-loader" role="class" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xi="http://www.w3.org/2001/XInclude">
<title>Класс Yaf_Loader</title>
<titleabbrev>Yaf_Loader</titleabbrev>
<partintro>
<!-- {{{ Yaf_Loader intro -->
<section xml:id="yaf-loader.intro">
&reftitle.intro;
<para>
<classname>Yaf_Loader</classname> представляет комплексное решение
для автозагрузки для Yaf.
</para>
<para>
При первом извлечении экземпляра <classname>Yaf_Application</classname>,
<classname>Yaf_Loader</classname> создаёт экземпляр-одиночку и регистрируется с помощью
spl_autoload. Вы извлекаете экземпляр, используя <methodname>Yaf_Loader::getInstance</methodname>
</para>
<para>
<classname>Yaf_Loader</classname> попытается загрузить класс только один раз, в случае
возникновения ошибки, зависит от <link
linkend="ini.yaf.use-spl-autoload">yaf.use_spl_auload</link>, если эта
конфигурация включена <methodname>Yaf_Loader::autoload</methodname> вернёт
&false;, таким образом предоставляя возможность другой функции автозагрузки. Если выключена
(по умолчанию), <methodname>Yaf_Loader::autoload</methodname> вернёт
&true;, а также сработает очень полезное предупреждение
(полезно, чтобы выяснить, почему класс не может быть загружен).
<note>
<para>
Пожалуйста, оставьте yaf.use_spl_autoload выключенным, если в какой-то библиотеке
нет собственного механизма автозагрузки и его невозможно переписать.
</para>
</note>
</para>
<para>
По умолчанию <classname>Yaf_Loader</classname> предполагает, что вся библиотека
(сценарий, определённый классом) хранится в <link linkend="ini.yaf.library">каталоге глобальной
библиотеки</link>, который определён в php.ini (yaf.library).
</para>
<para>
Если вы хотите с помощью <classname>Yaf_Loader</classname> выполнить поиск некоторых
классов (библиотек) в <link linkend="yaf-loader.props.library">каталоге локальных
классов</link> (который определён в application.ini,
по умолчанию это <link
linkend="configuration.yaf.directory">application.directory</link>. "/library"),
вы должны зарегистрировать префикс класса, используя
<methodname>Yaf_Loader::registerLocalNameSpace</methodname>
</para>
<para>
Давайте посмотрим несколько примеров (при условии, что APPLICATION_PATH <link
linkend="configuration.yaf.directory">application.directory</link>):
<example>
<title>Пример конфигурации</title>
<programlisting role="shell">
<![CDATA[
// Предполагаются следующие настройки в php.ini:
yaf.library = "/global_dir"
//Предполагаются следующие настройки в php.ini:
application.library = APPLICATION_PATH "/library"
]]>
</programlisting>
</example>
Предполагается, что зарегистрировано следующее локальное пространство имён:
<example>
<title>Зарегистрировать локальное пространство имён</title>
<programlisting role="php">
<![CDATA[
<?php
class Bootstrap extends Yaf_Bootstrap_Abstract{
public function _initLoader($dispatcher) {
Yaf_Loader::getInstance()->registerLocalNameSpace(array("Foo", "Bar"));
}
?>
]]>
</programlisting>
</example>
Тогда пример автозагрузки:
<example>
<title>Пример загрузки класса</title>
<programlisting role="shell">
<![CDATA[
class Foo_Bar_Test =>
// APPLICATION_PATH/library/Foo/Bar/Test.php
class GLO_Name =>
// /global_dir/Glo/Name.php
class BarNon_Test
// /global_dir/Barnon/Test.php
]]>
</programlisting>
</example>
<example>
<title>Пример загрузки класса имён</title>
<programlisting role="shell">
<![CDATA[
class \Foo\Bar\Dummy =>
// APPLICATION_PATH/library/Foo/Bar/Dummy.php
class \FooBar\Bar\Dummy =>
// /global_dir/FooBar/Bar/Dummy.php
]]>
</programlisting>
</example>
</para>
<para>
Вы можете заметить, что все папки с первой буквой заглавными, вы можете сделать их
строчными, установив <link linkend="ini.yaf.lowcase-path">yaf.lowcase_path</link> = On в php.ini.
</para>
<para>
<classname>Yaf_Loader</classname> также предназначен для загрузки
классов MVC, и правило таково:
<example>
<title>Пример загрузки класса MVC</title>
<programlisting role="shell">
<![CDATA[
Controller Classes =>
// APPLICATION_PATH/controllers/
Model Classes =>
// APPLICATION_PATH/models/
Plugin Classes =>
// APPLICATION_PATH/plugins/
]]>
</programlisting>
</example>
Yaf идентифицирует суффикс класса (это по умолчанию, вы также можете изменить
его на префикс, изменив конфигурацию <link
linkend="ini.yaf.name-suffix">yaf.name_suffix</link>), чтобы решить, является ли
он классом MVC:
<example>
<title>Классовые различия MVC</title>
<programlisting role="shell">
<![CDATA[
Controller Classes =>
// ***Controller
Model Classes =>
// ***Model
Plugin Classes =>
// ***Plugin
]]>
</programlisting>
</example>
несколько примеров:
<example>
<title>Пример загрузки MVC</title>
<programlisting role="shell">
<![CDATA[
class IndexController
// APPLICATION_PATH/controllers/Index.php
class DataModel =>
// APPLICATION_PATH/models/Data.php
class DummyPlugin =>
// APPLICATION_PATH/plugins/Dummy.php
class A_B_TestModel =>
// APPLICATION_PATH/models/A/B/Test.php
]]>
</programlisting>
</example>
<note>
<para>
Начиная с 2.1.18, Yaf поддерживает автозагрузку контроллеров для стороны пользовательского скрипта
(что означает автозагрузку, запускаемую пользовательским скриптом php, например: доступ
к статическому свойству контроллера в Bootstrap или плагинах),
но автозагрузчик только пытается найти скрипт класса контроллера в папке модуля по умолчанию,
которая называется "APPLICATION_PATH/controllers/".
</para>
</note>
также на каталог будет влиять <link linkend="ini.yaf.lowcase-path">yaf.lowcase_path</link>.
</para>
</section>
<!-- }}} -->
<section xml:id="yaf-loader.synopsis">
&reftitle.classsynopsis;
<!-- {{{ Synopsis -->
<classsynopsis>
<ooclass><classname>Yaf_Loader</classname></ooclass>
<!-- {{{ Class synopsis -->
<classsynopsisinfo>
<ooclass>
<classname>Yaf_Loader</classname>
</ooclass>
</classsynopsisinfo>
<!-- }}} -->
<classsynopsisinfo role="comment">&Properties;</classsynopsisinfo>
<fieldsynopsis>
<modifier>protected</modifier>
<varname linkend="yaf-loader.props.local-ns">_local_ns</varname>
</fieldsynopsis>
<fieldsynopsis>
<modifier>protected</modifier>
<varname linkend="yaf-loader.props.library">_library</varname>
</fieldsynopsis>
<fieldsynopsis>
<modifier>protected</modifier>
<varname linkend="yaf-loader.props.global-library">_global_library</varname>
</fieldsynopsis>
<fieldsynopsis>
<modifier>static</modifier>
<varname linkend="yaf-loader.props.instance">_instance</varname>
</fieldsynopsis>
<classsynopsisinfo role="comment">&Methods;</classsynopsisinfo>
<xi:include xpointer="xmlns(db=http://docbook.org/ns/docbook) xpointer(id('class.yaf-loader')/db:refentry/db:refsect1[@role='description']/descendant::db:constructorsynopsis[not(@role='procedural')])" />
<xi:include xpointer="xmlns(db=http://docbook.org/ns/docbook) xpointer(id('class.yaf-loader')/db:refentry/db:refsect1[@role='description']/descendant::db:methodsynopsis[1])" />
</classsynopsis>
<!-- }}} -->
</section>
<!-- {{{ Yaf_Loader properties -->
<section xml:id="yaf-loader.props">
&reftitle.properties;
<variablelist>
<varlistentry xml:id="yaf-loader.props.local-ns">
<term><varname>_local_ns</varname></term>
<listitem>
<para></para>
</listitem>
</varlistentry>
<varlistentry xml:id="yaf-loader.props.library">
<term><varname>_library</varname></term>
<listitem>
<para>
По умолчанию это значение равно <link
linkend="configuration.yaf.directory">application.directory</link> . "/library",
вы можете изменить это либо в application.ini(application.library), либо вызвать
<methodname>Yaf_Loader::setLibraryPath</methodname>
</para>
</listitem>
</varlistentry>
<varlistentry xml:id="yaf-loader.props.global-library">
<term><varname>_global_library</varname></term>
<listitem>
<para></para>
</listitem>
</varlistentry>
<varlistentry xml:id="yaf-loader.props.instance">
<term><varname>_instance</varname></term>
<listitem>
<para></para>
</listitem>
</varlistentry>
</variablelist>
</section>
<!-- }}} -->
</partintro>
&reference.yaf.entities.yaf-loader;
</reference>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->