ThinkPHP container binding parameters
“This article is mainly about learning how the __make method is executed in each method, and now that we have learned about the container, how can we use the container to call the configuration to obtain the configuration information? .
”
Analyze the bindParams method
Next, let’s analyze the bindParams
method.
Regarding parameter passing, it is a reflection class. The second parameter will not be explained for the time being. There is no response scenario yet.
The first parameter value$reflect
##Use the reflection method$reflect->getNumberOfParameters( )
Get the number of parameters in the corresponding method in the reflection class. According to the above, it is the __make method. The number of parameters of only two methods has been obtained in the container code, one is the __make method, and the other is the constructor in the reflection class.
Code$params = $reflect->getParameters();
also uses reflection to obtain the parameters of the method.
The results you can see when printing are two sets of data.
So where does this set of data come from? Scroll up and take a look at what the
$reflect
parameter is and you will understand.
think\App This reflection class does not have a __make method, so the parameters in the constructor will be obtained.
Then there is a __make method in the think\Log reflection class, so the parameters of __make will be returned, as shown below.
Just like a class like think\Log, which has both a __make method and a constructor, it will go twice bindParams
method , you should all understand this, it is exactly the logic in the picture below.
The next step is the parameters obtained in the loop reflection class.
Get the parameter name, and get the corresponding reflection class
Finally, pass the obtained reflection class to the getObjectParam
method.
There is not much content in this
getObjectParam
method.
Since $vars
is an empty array from beginning to end, the operation of removing the first element of the array and determining whether it is a closure will not be executed.
The make method will eventually be executed upon return
Then the make method will return the instance directly from the container
When a reflection class exists __make method,
return $method->invokeArgs(null, $args);
will eventually be executed, and the reflection class method will be executed with parameters
Use the container to call Configuration class
Now that I have read the container source code once, can I use the container to implement it?
Of course it is possible. Here you need to pay attention to the namespace of Kaka. For the convenience of future review, the class name is also named Container, so I added an alias. The one you are using Time is not needed!
As of now, the source code of the container is almost explained. Later, Kaka will make a complete flow chart for everyone to view.
“Persistence in learning, persistence in blogging, and persistence in sharing are the beliefs that Kaka has always upheld since his career. I hope that Kaka’s articles on the huge Internet can bring you a little bit of help. I’m Kaka, see you next time.
”
The above is the detailed content of ThinkPHP container binding parameters. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











To run the ThinkPHP project, you need to: install Composer; use Composer to create the project; enter the project directory and execute php bin/console serve; visit http://localhost:8000 to view the welcome page.

ThinkPHP has multiple versions designed for different PHP versions. Major versions include 3.2, 5.0, 5.1, and 6.0, while minor versions are used to fix bugs and provide new features. The latest stable version is ThinkPHP 6.0.16. When choosing a version, consider the PHP version, feature requirements, and community support. It is recommended to use the latest stable version for best performance and support.

Steps to run ThinkPHP Framework locally: Download and unzip ThinkPHP Framework to a local directory. Create a virtual host (optional) pointing to the ThinkPHP root directory. Configure database connection parameters. Start the web server. Initialize the ThinkPHP application. Access the ThinkPHP application URL and run it.

Performance comparison of Laravel and ThinkPHP frameworks: ThinkPHP generally performs better than Laravel, focusing on optimization and caching. Laravel performs well, but for complex applications, ThinkPHP may be a better fit.

ThinkPHP installation steps: Prepare PHP, Composer, and MySQL environments. Create projects using Composer. Install the ThinkPHP framework and dependencies. Configure database connection. Generate application code. Launch the application and visit http://localhost:8000.

"Development Suggestions: How to Use the ThinkPHP Framework to Implement Asynchronous Tasks" With the rapid development of Internet technology, Web applications have increasingly higher requirements for handling a large number of concurrent requests and complex business logic. In order to improve system performance and user experience, developers often consider using asynchronous tasks to perform some time-consuming operations, such as sending emails, processing file uploads, generating reports, etc. In the field of PHP, the ThinkPHP framework, as a popular development framework, provides some convenient ways to implement asynchronous tasks.

ThinkPHP is a high-performance PHP framework with advantages such as caching mechanism, code optimization, parallel processing and database optimization. Official performance tests show that it can handle more than 10,000 requests per second and is widely used in large-scale websites and enterprise systems such as JD.com and Ctrip in actual applications.

Development suggestions: How to use the ThinkPHP framework for API development. With the continuous development of the Internet, the importance of API (Application Programming Interface) has become increasingly prominent. API is a bridge for communication between different applications. It can realize data sharing, function calling and other operations, and provides developers with a relatively simple and fast development method. As an excellent PHP development framework, the ThinkPHP framework is efficient, scalable and easy to use.
