5 Composer Tips PHP Developers Should Know

青灯夜游
Release: 2020-01-02 09:56:30
forward
3089 people have browsed it

Composer is a new generation of PHP dependency management tool. This article introduces five tips for using Composer, hoping to bring convenience to your PHP development.

5 Composer Tips PHP Developers Should Know

1. Only update a single library

I only want to update a specific library and don’t want to update all its dependencies. This is very difficult. Simple

composer update foo/bar
Copy after login

In addition, this trick can also be used to solve the "warning message problem". You must have seen warning messages like this:

Warning: The lock file is not up to date with the latest changes in composer.json, you may be getting outdated dependencies, run update to update them.
Copy after login

Rub, what went wrong? Don't panic! If you edit composer.json, you should see something like this. For example, if you add or update details such as a library description, author, more parameters, or even just add a space, it will change the md5sum of the file. Composer will then warn you that the hash value is different from the one recorded in composer.lock.

So what should we do? The update command can update the lock file, but if it only adds some descriptions, it should not update any libraries. In this case, just update nothing:

$ composer update nothing

Loading composer repositories with package information

Updating dependencies

Nothing to install or update

Writing lock file

Generating autoload files
Copy after login

In this way, Composer will not update the library, but it will update composer.lock. Note that nothing is not a keyword in the update command. There is just nothing this package causes. If you type foobar, the result is the same.

If the Composer version you are using is new enough, you can use the --lock option directly:

composer update --lock
Copy after login

2. Install the library without editing composer.json

You may find it too troublesome to modify composer.json every time you install a library, then you can use the require command directly.

composer require "foo/bar:1.0.0"
Copy after login

This method can also be used to quickly open a new project. The init command has the --require option, which can automatically write composer.json: (note that we use -n so that we don’t have to answer the question)

$ composer init --require=foo/bar:1.0.0 -n
$ cat composer.json
{
    "require": {

        "foo/bar": "1.0.0"
    }
}
Copy after login

3. Derivating is easy

During initialization, have you tried the create-project command?

composer create-project doctrine/orm path 2.2.0
Copy after login

This will automatically clone the repository and check out the specified version. This command is very convenient to use when cloning a library, as there is no need to search for the original URI.

4. Consider caching, give priority to dist packages

Composer from the past year will automatically archive the dist package you downloaded. By default, the dist package is used for tagged versions, such as "symfony/symfony": "v2.1.4", or wildcards or version ranges, "2.1.*" or ">=2.2,<2.3- dev" (if you use stable as your minimum-stability).

dist package can also be used for branches such as dev-master. Github allows you to download a compressed package referenced by git. To force the use of a tarball instead of cloning the source code, you can use the --prefer-dist option of install and update.

The following is an example (I used the --profile option to display execution time):

$ composer init --require="twig/twig:1.*" -n --profile

Memory usage: 3.94MB (peak: 4.08MB), time: 0s

  

$ composer install --profile

Loading composer repositories with package information

Installing dependencies

  - Installing twig/twig (v1.12.2)

    Downloading: 100%

  

Writing lock file

Generating autoload files

Memory usage: 10.13MB (peak: 12.65MB), time: 4.71s

  

$ rm -rf vendor

  

$ composer install --profile

Loading composer repositories with package information

Installing dependencies from lock file

  - Installing twig/twig (v1.12.2)

    Loading from cache

  

Generating autoload files

Memory usage: 4.96MB (peak: 5.57MB), time: 0.45s
Copy after login

Here, the compressed package of twig/twig:1.12.2 is saved in ~/.composer /cache/files/twig/twig/1.12.2.0-v1.12.2.zip. Use it directly when reinstalling the package.

5. If you want to modify, source code first

When you need to modify the library, cloning the source code is more convenient than downloading the package. You can use --prefer-source to force selection of clone source code.

composer update symfony/yaml --prefer-source
Copy after login

Next you can modify the file:

composer status -v

You have changes in the following dependencies:

/path/to/app/vendor/symfony/yaml/Symfony/Component/Yaml:

    M Dumper.php
Copy after login

When you try to update a modified library, Composer will remind you and ask whether to abandon the modification:

$ composer update

Loading composer repositories with package information

Updating dependencies

  - Updating symfony/symfony v2.2.0 (v2.2.0- => v2.2.0)

    The package has modified files:

    M Dumper.php

    Discard changes [y,n,v,s,?]?</p>
<p> Preparing for the production environment</p>
<p>Finally, as a reminder, when deploying code to the production environment, don’t forget to optimize automatic loading: </p>
<pre class="brush:php;toolbar:false">composer dump-autoload --optimize
Copy after login

You can also use --optimize- when installing packages autoloader. Without this option, you may see a 20% to 25% performance loss.

For more composer-related technical articles, please visit the composer column! !

The above is the detailed content of 5 Composer Tips PHP Developers Should Know. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:cnblogs.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template