cari
Rumahpembangunan bahagian belakangtutorial phpSediakan penghalaan dalam aplikasi PHP menggunakan komponen penghalaan Symfony

Sediakan penghalaan dalam aplikasi PHP menggunakan komponen penghalaan Symfony

Sep 03, 2023 pm 10:37 PM
aplikasi phpkomponen penghalaan symfonySediakan penghalaan

Sediakan penghalaan dalam aplikasi PHP menggunakan komponen penghalaan Symfony

Apakah komponen penghalaan Symfony?

Komponen penghalaan Symfony ialah komponen penghalaan yang sangat popular yang disesuaikan daripada beberapa rangka kerja dan memberikan banyak fleksibiliti jika anda ingin menyediakan penghalaan dalam aplikasi PHP anda.

Jika anda telah membina aplikasi PHP tersuai dan sedang mencari perpustakaan penghalaan yang kaya dengan ciri, maka Symfony Routing Component ialah salah satu calon terbaik. Ia juga membolehkan anda menentukan laluan aplikasi anda dalam format YAML.

Bermula dengan pemasangan dan konfigurasi, kami akan menunjukkan melalui contoh praktikal pelbagai pilihan komponen ini untuk konfigurasi penghalaan. Dalam artikel ini anda akan belajar tentang:

  • Pemasangan dan konfigurasi komponen penghalaan Symfony
  • Bagaimana untuk menyediakan laluan asas
  • Cara memuatkan laluan dari fail YAML
  • Buat laluan sebagai ulasan: Cara yang disyorkan

Pemasangan dan konfigurasi

Dalam bahagian ini, kami akan memasang perpustakaan yang diperlukan untuk menyediakan penghalaan dalam aplikasi PHP. Saya menganggap anda sudah memasang Komposer pada sistem anda kerana kami memerlukannya untuk memasang perpustakaan yang diperlukan yang tersedia di Packagist.

Selepas memasang Komposer, teruskan memasang komponen penghalaan teras menggunakan arahan berikut.

$composer require symfony/routing

Walaupun komponen penghalaan itu sendiri mencukupi untuk menyediakan keupayaan penghalaan yang komprehensif dalam aplikasi anda, kami juga akan meneruskan dan memasang beberapa komponen tambahan untuk menjadikan kehidupan kami lebih mudah dan memperkayakan fungsi penghalaan teras sedia ada.

Pertama, kami akan meneruskan untuk memasang komponen HttpFoundation, yang menyediakan pembalut berorientasikan objek untuk pembolehubah global PHP dan fungsi berkaitan tindak balas. Ia memastikan bahawa anda tidak perlu mengakses terus pembolehubah global seperti $_GET, $_POST dsb. $_GET$_POST 等全局变量。

$composer require symfony/http-foundation

接下来,如果您想在 YAML 文件而不是 PHP 代码中定义应用程序路由,则 YAML 组件可以发挥作用,因为它可以帮助您将 YAML 字符串转换为 PHP 数组,反之亦然。

$composer require symfony/yaml

最后,我们将安装 Config 组件,它提供了几个实用程序类来初始化和处理不同类型文件(如 YAML、INI、XML 等)中定义的配置值。在我们的例子中,我们将使用它从 YAML 文件加载路由。

$composer require symfony/config

这就是安装部分,但是你应该如何使用它呢?事实上,只需将 Composer 创建的 autoload.php 文件包含在您的应用程序中即可,如以下代码片段所示。

<?php
require_once './vendor/autoload.php';
 
// application code
?>

设置基本路由

在上一节中,我们完成了必要的路由组件的安装。现在,您可以立即在 PHP 应用程序中设置路由。

让我们继续创建包含以下内容的 basic_routes.php 文件。

<?php
require_once './vendor/autoload.php';
 
use Symfony\Component\Routing\Matcher\UrlMatcher;
use Symfony\Component\Routing\RequestContext;
use Symfony\Component\Routing\RouteCollection;
use Symfony\Component\Routing\Route;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\Generator\UrlGenerator;
use Symfony\Component\Routing\Exception\ResourceNotFoundException;
 
try
{
    // Init basic route
    $foo_route = new Route(
      '/foo',
      array('controller' => 'FooController')
    );
 
    // Init route with dynamic placeholders
    $foo_placeholder_route = new Route(
      '/foo/{id}',
      array('controller' => 'FooController', 'method'=>'load'),
      array('id' => '[0-9]+')
    );
 
    // Add Route object(s) to RouteCollection object
    $routes = new RouteCollection();
    $routes->add('foo_route', $foo_route);
    $routes->add('foo_placeholder_route', $foo_placeholder_route);
 
    // Init RequestContext object
    $context = new RequestContext();
    $context->fromRequest(Request::createFromGlobals());
 
    // Init UrlMatcher object
    $matcher = new UrlMatcher($routes, $context);
 
    // Find the current route
    $parameters = $matcher->match($context->getPathInfo());
 
    // How to generate a SEO URL
    $generator = new UrlGenerator($routes, $context);
    $url = $generator->generate('foo_placeholder_route', array(
      'id' => 123,
    ));
 
    echo '<pre class="brush:php;toolbar:false">';
    print_r($parameters);
 
    echo 'Generated URL: ' . $url;
    exit;
}
catch (ResourceNotFoundException $e)
{
  echo $e->getMessage();
}

使用 Symfony Routing 组件设置路由通常要经历如下列出的一系列步骤。

  • 为每个应用程序路由初始化 Route 对象。
  • 将所有 Route 对象添加到 RouteCollection 对象。
  • 初始化 RequestContext 对象,该对象保存当前请求上下文信息。
  • 通过传递 RouteCollection 对象和 RequestContext 对象来初始化 UrlMatcher 对象。

初始化不同路由的路由对象

让我们继续定义一个非常基本的 foo 路由。

$foo_route = new Route(
  '/foo',
  array('controller' => 'FooController')
);

Route 构造函数的第一个参数是 URI 路径,第二个参数是匹配此特定路由时要返回的自定义属性数组。通常,它是控制器和方法的组合,当请求此路由时您要调用它们。

接下来我们看一下参数化路由。

$foo_placeholder_route = new Route(
  '/foo/{id}',
  array('controller' => 'FooController', 'method'=>'load'),
  array('id' => '[0-9]+')
);

上述路由可以匹配 foo/1foo/123 等类似的 URI。请注意,我们将 {id} 参数限制为仅限数字值,因此它不会匹配 foo/bar 这样的 URI,因为 {id} 参数以字符串形式提供。

将所有路由对象添加到 RouteCollection 对象

下一步是将我们在上一节中初始化的路由对象添加到 RouteCollection

$routes = new RouteCollection();
$routes->add('foo_route', $foo_route);
$routes->add('foo_placeholder_route', $foo_placeholder_route);

Seterusnya, jika anda ingin menentukan laluan aplikasi anda dalam fail YAML dan bukannya kod PHP, komponen YAML akan dimainkan kerana ia membantu anda menukar rentetan YAML kepada tatasusunan PHP dan sebaliknya.
$context = new RequestContext();
$context->fromRequest(Request::createFromGlobals());
🎜Akhir sekali, kami akan memasang komponen Config, yang menyediakan beberapa kelas utiliti untuk memulakan dan memproses nilai konfigurasi yang ditakrifkan dalam jenis fail yang berbeza (seperti YAML, INI, XML, dll.). Dalam kes kami, kami akan menggunakan ini untuk memuatkan laluan daripada fail YAML. 🎜
// Init UrlMatcher object
$matcher = new UrlMatcher($routes, $context);
🎜Itu bahagian pemasangan, tetapi bagaimana anda sepatutnya menggunakannya? Malah, masukkan sahaja fail autoload.php yang dibuat oleh Composer ke dalam aplikasi anda, seperti yang ditunjukkan dalam coretan kod berikut. 🎜
$parameters = $matcher->match($context->getPathInfo());

Tetapkan laluan asas🎜 🎜Dalam bahagian sebelumnya, kami telah menyelesaikan pemasangan komponen penghalaan yang diperlukan. Kini anda boleh menyediakan penghalaan serta-merta dalam aplikasi PHP anda. 🎜 🎜Mari teruskan dan buat fail basic_routes.php dengan kandungan berikut. 🎜
Array
(
    [controller] => FooController
    [_route] => foo_route
)
🎜Menyediakan penghalaan menggunakan komponen Penghalaan Symfony biasanya melibatkan satu siri langkah yang disenaraikan di bawah. 🎜 🎜

  • Memulakan objek Route untuk setiap laluan aplikasi. 🎜
  • Tambah semua objek Route pada objek RouteCollection. 🎜
  • Memulakan objek RequestContext, yang menyimpan maklumat konteks permintaan semasa. 🎜
  • Mulakan objek UrlMatcher dengan menghantar objek RouteCollection dan RequestContext objek. 🎜 🎜

    Mulakan objek penghalaan untuk laluan berbeza

    🎜Mari kita teruskan dan tentukan laluan foo yang sangat asas. 🎜
    Array
    (
        [controller] => FooController
        [method] => load
        [id] => 123
        [_route] => foo_placeholder_route
    )
    
    Parameter pertama pembina 🎜Route ialah laluan URI dan parameter kedua ialah tatasusunan sifat tersuai yang akan dikembalikan apabila memadankan laluan khusus ini. Biasanya, ini adalah gabungan pengawal dan kaedah yang anda panggil apabila laluan ini diminta. 🎜 🎜Seterusnya mari kita lihat pada penghalaan berparameter. 🎜
    No routes found for "/unknown-route".
    
    🎜Laluan di atas boleh memadankan foo/1, foo/123 dan URI lain yang serupa. Harap maklum bahawa kami mengehadkan parameter {id} kepada nilai angka sahaja, jadi ia tidak akan sepadan dengan foo/bar seperti URI ini kerana parameter {id} disediakan sebagai rentetan. 🎜

    Tambahkan semua objek laluan pada objek RouteCollection

    🎜Langkah seterusnya ialah menambah objek laluan yang kami mulakan dalam bahagian sebelumnya pada objek RouteCollection. 🎜
    $routes = new RouteCollection();
    $routes->add('foo_route', $foo_route);
    $routes->add('foo_placeholder_route', $foo_placeholder_route);
    

    正如您所看到的,这非常简单,您只需要使用 RouteCollection 对象的 add 方法来添加路由对象。 add 方法的第一个参数是路由名称,第二个参数是路由对象本身。

    初始化 RequestContext 对象

    接下来,我们需要初始化RequestContext对象,该对象保存当前请求上下文信息。当我们初始化 UrlMatcher 对象时,我们将需要这个对象,因为我们稍后会详细介绍它。

    $context = new RequestContext();
    $context->fromRequest(Request::createFromGlobals());
    

    初始化 UrlMatcher 对象

    最后,我们需要初始化 UrlMatcher 对象以及路由和上下文信息。

    // Init UrlMatcher object
    $matcher = new UrlMatcher($routes, $context);
    

    现在,我们拥有了可以匹配路线的一切。

    如何匹配路由

    这是 UrlMatcher 对象的 match 方法,它允许您将任何路由与一组预定义路由进行匹配。

    match 方法将 URI 作为其第一个参数,并尝试将其与预定义的路由进行匹配。如果找到该路由,它将返回与该路由关联的自定义属性。另一方面,如果没有与当前 URI 关联的路由,它会抛出 ResourceNotFoundException 异常。

    $parameters = $matcher->match($context->getPathInfo());
    

    在我们的例子中,我们通过从 $context 对象获取当前 URI 来提供它。因此,如果您访问 https://your-domain/basic_routes.php/foo URL,则 $context->getPathInfo() 返回 foo,并且我们已经为 foo URI 定义了一条路由,因此它应该返回以下内容。

    Array
    (
        [controller] => FooController
        [_route] => foo_route
    )
    

    现在,让我们继续访问 http://your-domain/basic_routes.php/foo/123 URL 来测试参数化路由。

    Array
    (
        [controller] => FooController
        [method] => load
        [id] => 123
        [_route] => foo_placeholder_route
    )
    

    如果您可以看到 id 参数与适当的值 123 绑定,则说明有效。

    接下来,让我们尝试访问不存在的路由,例如 http://your-domain/basic_routes.php/unknown-route,您应该会看到以下消息。

    No routes found for "/unknown-route".
    

    这就是如何使用 match 方法查找路由。

    除此之外,您还可以使用路由组件在应用程序中生成链接。提供了 RouteCollectionRequestContext 对象,UrlGenerator 允许您为特定路由构建链接。

    $generator = new UrlGenerator($routes, $context);
    $url = $generator->generate('foo_placeholder_route', array(
      'id' => 123,
    ));
    

    generate 方法的第一个参数是路由名称,第二个参数是数组,如果是参数化路由,则可以包含参数。上面的代码应该生成 /basic_routes.php/foo/123 URL。

    从 YAML 文件加载路由

    在上一节中,我们使用 RouteRouteCollection 对象构建了自定义路由。事实上,路由组件提供了不同的方式供您选择来实例化路由。您可以从各种加载器中进行选择,例如 YamlFileLoaderXmlFileLoaderPhpFileLoader

    在本节中,我们将通过 YamlFileLoader 加载器来了解如何从 YAML 文件加载路由。

    路由 YAML 文件

    继续创建包含以下内容的 routes.yaml 文件。

    foo_route:
        path:     /foo
        controller: App\Controller\FooController::index
        methods:    GET
     
    foo_placeholder_route:
        path:     /foo/{id}
        controller: App\Controller\FooController::load
        methods:    GET
        requirements:
            id: '[0-9]+'
    

    示例文件

    接下来,继续使用以下内容创建 load_routes_from_yaml.php 文件。

    load('routes.yaml');
     
        // Init RequestContext object
        $context = new RequestContext();
        $context->fromRequest(Request::createFromGlobals());
     
        // Init UrlMatcher object
        $matcher = new UrlMatcher($routes, $context);
     
        // Find the current route
        $parameters = $matcher->match($context->getPathInfo());
     
        // How to generate a SEO URL
        $generator = new UrlGenerator($routes, $context);
        $url = $generator->generate('foo_placeholder_route', array(
          'id' => 123,
        ));
     
        echo '
    ';
        print_r($parameters);
     
        echo 'Generated URL: ' . $url;
        exit;
    }
    catch (ResourceNotFoundException $e)
    {
      echo $e->getMessage();
    }
    

    在这种情况下唯一不同的是我们初始化路由的方式!

    $fileLocator = new FileLocator(array(__DIR__));
    $loader = new YamlFileLoader($fileLocator);
    $routes = $loader->load('routes.yaml');
    

    我们使用 YamlFileLoader 加载器从 routes.yaml 文件加载路由,而不是直接在 PHP 本身中对其进行初始化。除此之外,一切都是相同的,并且应该产生与 basic_routes.php 文件相同的结果。

    一体化路由器

    在本节中,我们将介绍 Router 类,它允许您使用更少的代码行快速设置路由。

    继续制作包含以下内容的 all_in_one_router.php 文件。

    <?php
    require_once './vendor/autoload.php';
     
    use Symfony\Component\Routing\RequestContext;
    use Symfony\Component\Routing\Router;
    use Symfony\Component\HttpFoundation\Request;
    use Symfony\Component\Routing\Generator\UrlGenerator;
    use Symfony\Component\Config\FileLocator;
    use Symfony\Component\Routing\Loader\YamlFileLoader;
    use Symfony\Component\Routing\Exception\ResourceNotFoundException;
     
    try
    {
        $fileLocator = new FileLocator(array(__DIR__));
     
        $requestContext = new RequestContext();
        $requestContext->fromRequest(Request::createFromGlobals());
     
        $router = new Router(
            new YamlFileLoader($fileLocator),
            'routes.yaml',
            array('cache_dir' => __DIR__.'/cache'),
            $requestContext
        );
     
        // Find the current route
        $parameters = $router->match($requestContext->getPathInfo());
     
        // How to generate a SEO URL
        $routes = $router->getRouteCollection();
        $generator = new UrlGenerator($routes, $requestContext);
        $url = $generator->generate('foo_placeholder_route', array(
          'id' => 123,
        ));
     
        echo '<pre class="brush:php;toolbar:false">';
        print_r($parameters);
     
        echo 'Generated URL: ' . $url;
        exit;
    }
    catch (ResourceNotFoundException $e)
    {
      echo $e->getMessage();
    }
    

    一切都几乎相同,除了我们实例化了 Router 对象以及必要的依赖项。

    $router = new Router(
        new YamlFileLoader($fileLocator),
        'routes.yaml',
        array('cache_dir' => __DIR__.'/cache'),
        $requestContext
    );
    

    完成后,您可以立即使用 Router 对象的 match 方法进行路由映射。

    $parameters = $router->match($requestContext->getPathInfo());
    

    此外,您还需要使用 Router 对象的 getRouteCollection 方法来获取路由。

    $routes = $router->getRouteCollection();
    

    将路由创建为注释:推荐方式

    在本节中,我们将讨论如何实现基于注释的路由。它正在成为在不同框架之间定义路由的最流行的方法之一。

    在我们继续实现基于注释的路由之前,我们需要安装几个软件包。让我们快速完成此操作,如以下代码片段所示。

    $composer require symfony/framework-bundle
    $composer require doctrine/annotations
    $composer require doctrine/cache
    

    如您所见,我们安装了三个不同的组件。

    在您的 composer.json 文件中,添加以下内容:

    "autoload": {
        "psr-4": {
            "App\\": "app/"
        }
    }
    

    现在,运行以下命令。

    $composer dump-autoload
    

    现在,我们准备好文件了。

    继续创建包含以下内容的 index.php 文件。

    load(__DIR__ . '/src/Controller/');
    $context = new RequestContext();
    $context->fromRequest(Request::createFromGlobals());
    
    $matcher = new UrlMatcher($routes, $context);
    $parameters = $matcher->match($context->getPathInfo());
    
    $controllerInfo = explode('::',$parameters['_controller']);
    
    $controller = new $controllerInfo[0];
    $action = $controllerInfo[1];
    
    $controller->$action();
    

    现在,让我们在 src/Controller/FooController.php 中创建包含以下内容的控制器文件。

    <?php
    namespace App\Controller;
    
    use Symfony\Component\Routing\Annotation\Route;
    
    class DefaultController
    {
        /**
         * @Route("/",name="index")
         */
        public function index()
        {
            echo "Index action";
        }
    
        /**
         * @Route("/hello",name="hello")
         */
        public function hello()
        {
            echo "Hello action";
        }
    }
    

    您可能已经注意到,我们以注释的形式为每个方法定义了路由。这种方法的好处是,它允许您在与这些路由关联的控制器的代码旁边定义路由。

    继续访问 https://your-domain/index.php/ URL。根据以下路由配置,它应该调用 index 方法。

    /**
     * @Route("/",name="index")
     */
    

    另一方面,如果您尝试访问 http://your-domain/index.php/hello URL,它应该调用 DefaultController 控制器的 hello 方法类。

    这就是基于注释的路由的工作原理!

    结论

    继续探索路由组件中可用的其他选项。

    今天,我们探索了 Symfony 路由组件,它使得在 PHP 应用程序中实现路由变得轻而易举。在此过程中,我们创建了一些示例来演示路由组件的各个方面。

  • Atas ialah kandungan terperinci Sediakan penghalaan dalam aplikasi PHP menggunakan komponen penghalaan Symfony. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan
    Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
    Status Semasa PHP: Lihat trend pembangunan webStatus Semasa PHP: Lihat trend pembangunan webApr 13, 2025 am 12:20 AM

    PHP tetap penting dalam pembangunan web moden, terutamanya dalam pengurusan kandungan dan platform e-dagang. 1) PHP mempunyai ekosistem yang kaya dan sokongan rangka kerja yang kuat, seperti Laravel dan Symfony. 2) Pengoptimuman prestasi boleh dicapai melalui OPCACHE dan NGINX. 3) Php8.0 memperkenalkan pengkompil JIT untuk meningkatkan prestasi. 4) Aplikasi awan asli dikerahkan melalui Docker dan Kubernet untuk meningkatkan fleksibiliti dan skalabiliti.

    PHP vs Bahasa Lain: PerbandinganPHP vs Bahasa Lain: PerbandinganApr 13, 2025 am 12:19 AM

    PHP sesuai untuk pembangunan web, terutamanya dalam pembangunan pesat dan memproses kandungan dinamik, tetapi tidak baik pada sains data dan aplikasi peringkat perusahaan. Berbanding dengan Python, PHP mempunyai lebih banyak kelebihan dalam pembangunan web, tetapi tidak sebaik python dalam bidang sains data; Berbanding dengan Java, PHP melakukan lebih buruk dalam aplikasi peringkat perusahaan, tetapi lebih fleksibel dalam pembangunan web; Berbanding dengan JavaScript, PHP lebih ringkas dalam pembangunan back-end, tetapi tidak sebaik JavaScript dalam pembangunan front-end.

    PHP vs Python: Ciri dan Fungsi TerasPHP vs Python: Ciri dan Fungsi TerasApr 13, 2025 am 12:16 AM

    PHP dan Python masing -masing mempunyai kelebihan sendiri dan sesuai untuk senario yang berbeza. 1.PHP sesuai untuk pembangunan web dan menyediakan pelayan web terbina dalam dan perpustakaan fungsi yang kaya. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan standard yang kuat. Apabila memilih, ia harus diputuskan berdasarkan keperluan projek.

    PHP: Bahasa utama untuk pembangunan webPHP: Bahasa utama untuk pembangunan webApr 13, 2025 am 12:08 AM

    PHP adalah bahasa skrip yang digunakan secara meluas di sisi pelayan, terutamanya sesuai untuk pembangunan web. 1.PHP boleh membenamkan HTML, memproses permintaan dan respons HTTP, dan menyokong pelbagai pangkalan data. 2.PHP digunakan untuk menjana kandungan web dinamik, data borang proses, pangkalan data akses, dan lain -lain, dengan sokongan komuniti yang kuat dan sumber sumber terbuka. 3. PHP adalah bahasa yang ditafsirkan, dan proses pelaksanaan termasuk analisis leksikal, analisis tatabahasa, penyusunan dan pelaksanaan. 4.Php boleh digabungkan dengan MySQL untuk aplikasi lanjutan seperti sistem pendaftaran pengguna. 5. Apabila debugging php, anda boleh menggunakan fungsi seperti error_reporting () dan var_dump (). 6. Mengoptimumkan kod PHP untuk menggunakan mekanisme caching, mengoptimumkan pertanyaan pangkalan data dan menggunakan fungsi terbina dalam. 7

    PHP: asas banyak laman webPHP: asas banyak laman webApr 13, 2025 am 12:07 AM

    Sebab mengapa PHP adalah timbunan teknologi pilihan untuk banyak laman web termasuk kemudahan penggunaannya, sokongan komuniti yang kuat, dan penggunaan yang meluas. 1) Mudah dipelajari dan digunakan, sesuai untuk pemula. 2) Mempunyai komuniti pemaju yang besar dan sumber yang kaya. 3) Digunakan secara meluas dalam platform WordPress, Drupal dan lain -lain. 4) Mengintegrasikan dengan ketat dengan pelayan web untuk memudahkan penggunaan pembangunan.

    Di luar gembar -gembur: Menilai peranan PHP hari iniDi luar gembar -gembur: Menilai peranan PHP hari iniApr 12, 2025 am 12:17 AM

    PHP kekal sebagai alat yang kuat dan digunakan secara meluas dalam pengaturcaraan moden, terutamanya dalam bidang pembangunan web. 1) PHP mudah digunakan dan diintegrasikan dengan lancar dengan pangkalan data, dan merupakan pilihan pertama bagi banyak pemaju. 2) Ia menyokong penjanaan kandungan dinamik dan pengaturcaraan berorientasikan objek, sesuai untuk membuat dan mengekalkan laman web dengan cepat. 3) Prestasi PHP dapat ditingkatkan dengan caching dan mengoptimumkan pertanyaan pangkalan data, dan komuniti yang luas dan ekosistem yang kaya menjadikannya masih penting dalam timbunan teknologi hari ini.

    Apakah rujukan yang lemah dalam PHP dan bilakah mereka berguna?Apakah rujukan yang lemah dalam PHP dan bilakah mereka berguna?Apr 12, 2025 am 12:13 AM

    Dalam PHP, rujukan lemah dilaksanakan melalui kelas lemah dan tidak akan menghalang pemungut sampah daripada menebus objek. Rujukan lemah sesuai untuk senario seperti sistem caching dan pendengar acara. Harus diingat bahawa ia tidak dapat menjamin kelangsungan hidup objek dan pengumpulan sampah mungkin ditangguhkan.

    Terangkan kaedah sihir __invoke dalam PHP.Terangkan kaedah sihir __invoke dalam PHP.Apr 12, 2025 am 12:07 AM

    Kaedah \ _ \ _ membolehkan objek dipanggil seperti fungsi. 1. Tentukan kaedah \ _ \ _ supaya objek boleh dipanggil. 2. Apabila menggunakan sintaks $ OBJ (...), PHP akan melaksanakan kaedah \ _ \ _ invoke. 3. Sesuai untuk senario seperti pembalakan dan kalkulator, meningkatkan fleksibiliti kod dan kebolehbacaan.

    See all articles

    Alat AI Hot

    Undresser.AI Undress

    Undresser.AI Undress

    Apl berkuasa AI untuk mencipta foto bogel yang realistik

    AI Clothes Remover

    AI Clothes Remover

    Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

    Undress AI Tool

    Undress AI Tool

    Gambar buka pakaian secara percuma

    Clothoff.io

    Clothoff.io

    Penyingkiran pakaian AI

    AI Hentai Generator

    AI Hentai Generator

    Menjana ai hentai secara percuma.

    Artikel Panas

    R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
    3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Tetapan grafik terbaik
    3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
    3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
    WWE 2K25: Cara Membuka Segala -galanya Di Myrise
    4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

    Alat panas

    Pelayar Peperiksaan Selamat

    Pelayar Peperiksaan Selamat

    Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

    MantisBT

    MantisBT

    Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

    Penyesuai Pelayan SAP NetWeaver untuk Eclipse

    Penyesuai Pelayan SAP NetWeaver untuk Eclipse

    Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

    SublimeText3 versi Inggeris

    SublimeText3 versi Inggeris

    Disyorkan: Versi Win, menyokong gesaan kod!

    SublimeText3 versi Mac

    SublimeText3 versi Mac

    Perisian penyuntingan kod peringkat Tuhan (SublimeText3)