摘要:关于一些学习和理解不是一个包管理器。其中一些库依赖于其他库。范围通过使用比较操作符可以指定有效的版本范围。赋值运算符这对于遵循语义化版本号的项目非常有用。指定最低版本,但允许版本号的最后一位数字上升。
关于composer一些学习和理解
Composer 不是一个包管理器。是的,它涉及 "packages" 和 "libraries",但它在每个项目的基础上进行管理,在你项目的某个目录中(例如 vendor)进行安装。默认情况下它不会在全局安装任何东西。因此,这仅仅是一个依赖管理。
这种想法并不新鲜,Composer 受到了 node"s npm 和 ruby"s bundler 的强烈启发。而当时 PHP 下并没有类似的工具。
Composer 将这样为你解决问题:
你有一个项目依赖于若干个库。
其中一些库依赖于其他库。
你声明你所依赖的东西。
Composer 会找出哪个版本的包需要安装,并安装它们(将它们下载到你的项目中)。
下载安装composer因为laravel是使用composer管理的,所以一切以laravel为基础。
这里补充的是:
因为某些原因,访问国外的composer资源网站很慢,导致composer install或者update的时候经常连接超时而出错,所以改为中国镜像
全局: composer config -g repo.packagist composer https://packagist.phpcomposer.com 局部项目(需要在项目当前目录下执行): composer config repo.packagist composer https://packagist.phpcomposer.com
执行完命令后会在composer.json文件里面增加这段,这样就代表添加中国镜像成功了,以后执行composer install或者update之类的命令的时候就会优先使用这个镜像
"repositories": { "packagist": { "type": "composer", "url": "https://packagist.phpcomposer.com" } }
关于composer.json文件用composer selfupdate来保持composer工具本身的版本更新
{ "name": "laravel/laravel", "description": "The Laravel Framework.", "keywords": ["framework", "laravel"], "license": "MIT", "type": "project", "require": { //这里是告诉composer必须要安装的项目,相当于生产环境 "php": ">=5.5.9", "laravel/framework": "5.2.*", //require 需要一个 包名称,这个就是包名称 "laravelcollective/html": "5.2.*", "yuanchao/laravel-5-markdown-editor": "dev-master" }, "require-dev": { //这个是开发需要安装的项目,相当于开发环境,可以通过-no-dev来取消安装这个项目里面的包 "fzaninotto/faker": "~1.4", "mockery/mockery": "0.9.*", "phpunit/phpunit": "~4.0", "symfony/css-selector": "2.8.*|3.0.*", "symfony/dom-crawler": "2.8.*|3.0.*" }, "autoload": { "classmap": [ "database" ], "psr-4": { "App": "app/" } }, "autoload-dev": { "classmap": [ "tests/TestCase.php" ] }, "scripts": { "post-root-package-install": [ "php -r "copy(".env.example", ".env");"" ], "post-create-project-cmd": [ "php artisan key:generate" ], "post-install-cmd": [ "IlluminateFoundationComposerScripts::postInstall", "php artisan optimize" ], "post-update-cmd": [ "IlluminateFoundationComposerScripts::postUpdate", "php artisan optimize" ] }, "config": { "preferred-install": "dist" } }
包名称的版本
确切的版本号--------1.0.2---------你可以指定包的确切版本。 范围-------->=1.0 >=1.0,<2.0 >=1.0,<1.1|>=1.2--------通过使用比较操作符可以指定有效的版本范围。 有效的运算符:>、>=、<、<=、!=。你可以定义多个范围,用逗号隔开,这将被视为一个逻辑AND处理。一个管道符号|将作为逻辑OR处理。 AND 的优先级高于 OR。 通配符--------1.0.*--------你可以使用通配符*来指定一种模式。1.0.*与>=1.0,<1.1是等效的。 赋值运算符--------~1.2--------这对于遵循语义化版本号的项目非常有用。~1.2相当于>=1.2,<2.0。
基本用法我们需要重点关注通配符和波浪符,通配符很好理解,波浪符有点拗口,~ 最好用例子来解释: ~1.2 相当于 >=1.2,<2.0(标记你所依赖的最低版本),而 ~1.2.3 相当于 >=1.2.3,<1.3。(指定最低版本,但允许版本号的最后一位数字上升。)语义化很难懂,但是直接看例子是可以知道怎么用的
composer是通过读取composer.json和composer.lock文件来进行安装包的
在安装依赖后,Composer 将把安装时确切的版本号列表写入 composer.lock 文件。这将锁定改项目的特定版本。因为 install 命令将会检查锁文件是否存在,如果存在,它将下载指定的版本(忽略 composer.json 文件中的定义)。如果不存在 composer.lock 文件,Composer 将读取 composer.json 并创建锁文件。
一般的使用用法有:
composer install (install 命令从当前目录读取 composer.json 文件,处理了依赖关系,并把其安装到 vendor 目录下。)
composer install XXXX (这是多带带安装某些包的时候使用)
composer update (为了获取依赖的最新版本,并且升级 composer.lock 文件,)
composer update XXX (类似)
--prefer-source: 下载包的方式有两种: source 和 dist。对于稳定版本 composer 将默认使用 dist 方式。而 source 表示版本控制源 。如果 --prefer-source 是被启用的,composer 将从 source 安装(如果有的话)。如果想要使用一个 bugfix 到你的项目,这是非常有用的。并且可以直接从本地的版本库直接获取依赖关系。 --prefer-dist: 与 --prefer-source 相反,composer 将尽可能的从 dist 获取,这将大幅度的加快在 build servers 上的安装。这也是一个回避 git 问题的途径,如果你不清楚如何正确的设置。 --dry-run: 如果你只是想演示而并非实际安装一个包,你可以运行 --dry-run 命令,它将模拟安装并显示将会发生什么。 --dev: 安装 require-dev 字段中列出的包(这是一个默认值)。 --no-dev: 跳过 require-dev 字段中列出的包。 --no-scripts: 跳过 composer.json 文件中定义的脚本。 --no-plugins: 关闭 plugins。 --no-progress: 移除进度信息,这可以避免一些不处理换行的终端或脚本出现混乱的显示。 --optimize-autoloader (-o): 转换 PSR-0/4 autoloading 到 classmap 可以获得更快的加载支持。特别是在生产环境下建议这么做,但由于运行需要一些时间,因此并没有作为默认值。
composer require(require 命令增加新的依赖包到当前目录的 composer.json 文件中。但并不即可更新)
composer dump-autoload(某些情况下你需要更新 autoloader,例如在你的包中加入了一个新的类。)
自动加载composer的自动加载会生产这个文件vendor/autoload.php,然后调用这个文件就能够获得文件里面的类的自动加载
自动加载只支持 PSR-4和 PSR-0两种命名方式
Under the psr-4 key you define a mapping from namespaces to paths, relative to the package root. { "autoload": { "psr-4": { "Monolog": "src/", //这里写法其实差不多,但是展现的意义并不相同,psr4会设定一个命名空间作为包的根目录,举例这行的意思是src/目录映射成为Monolog根目录,那么调用这个包的时候写MonologBarBaz,其实自动加载就会去这里src/Bar/Baz.php找类文件,然后加载 "VendorNamespace": "" } } } 在 psr-0 key 下你定义了一个命名空间到实际路径的映射(相对于包的根目录) { "autoload": { "psr-0": { "Monolog": "src/", //这里的意思是src/目录映射为Monolog,如果要调用MonologBarBaz,那么自动加载就会去src/Monolog/Bar/Baz.php,然后加载 "VendorNamespace": "src/", "Vendor_Namespace_": "src/" } } }
laravel的自动加载会多了一些东西
vendor/autoload.php引用参考:
http://docs.phpcomposer.com/00-intro.html
https://getcomposer.org/doc/00-intro.md
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/22498.html
摘要:因为箭头函数本身没有所以不可以当作构造函数,也就是说,不可以使用命令,否则会抛出一个错误。箭头函数不可以使用对象,该对象在函数体内不存在。 es6学习笔记-箭头函数_v1.0 箭头函数使用方法 var f = v => v; //普通函数配合箭头函数写法,这里并且是传参的 //相当于 var f = function(v) { return v; }; /*-----------...
摘要:考虑到环境导致的行为差异太大,应该避免在块级作用域内声明函数。函数声明语句函数表达式循环循环还有一个特别之处,就是循环语句部分是一个父作用域,而循环体内部是一个单独的子作用域。声明一个只读的常量。 es6学习笔记-let,const和块级作用域_v1.0 块级作用域 javascript 原来是没有块级作用域的,只有全局作用域和函数作用域 例子1 因为没有块级作用域,所以每次的i都是一...
摘要:关于的包的使用笔记关于安装官网已经很详细了不再描述关于导入导入的话只有几个小地方需要注意导入的时候会有产生一些的在循环遍历导入的数据的时候主动忽略关于中文或者乱码问题或者在配置文件在安装这个模块的文档有介绍怎么生成这个文件 关于laravel5的excel包maatwebsite/excel的使用笔记 关于安装 官网已经很详细了,不再描述.http://www.maatwebsite....
摘要:学习笔记数值的扩展有一些不常用或者还不支持的就没有记录了总体来说本篇只是一个备忘而已用来检查一个数值是否为有限的。两个新方法只对数值有效,非数值一律返回。参考引用数值扩展 es6学习笔记-数值的扩展 有一些不常用或者还不支持的就没有记录了,总体来说本篇只是一个备忘而已 Number.isFinite(), Number.isNaN() Number.isFinite()用来检查一个数值...
摘要:学习笔记顶层对象虽然是笔记但是基本是抄了一次大师的文章了顶层对象顶层对象,在浏览器环境指的是对象,在指的是对象。之中,顶层对象的属性与全局变量是等价的。的写法模块的写法上面代码将顶层对象放入变量。参考引用顶层对象实战 es6学习笔记-顶层对象_v1.0 (虽然是笔记,但是基本是抄了一次ruan大师的文章了) 顶层对象 顶层对象,在浏览器环境指的是window对象,在Node指的是gl...
阅读 2957·2021-11-16 11:42
阅读 3619·2021-09-08 09:36
阅读 903·2019-08-30 12:52
阅读 2466·2019-08-29 14:12
阅读 722·2019-08-29 13:53
阅读 3561·2019-08-29 12:16
阅读 626·2019-08-29 12:12
阅读 2452·2019-08-29 11:16