PHP使用Composer进行注册全局函数

编程之家收集整理的这篇文章主要介绍了PHP使用Composer进行注册全局函数编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

概述

PHP使用Composer进行注册全局函数
Composer 使用不同的技术和标准简化了类的自动加载。当今最常见的自动加载标准是 PSR-4:

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

这将使用带有 “App” 名称空间前缀的 PSR-4 标准将 src 文件夹中的所有类自动加载。但是,我们如何自动加载不直接属于命名空间类的文件、全局帮助程序函数呢?那么,如果你在 Composer 网站上浏览官方文档 , 你可以看到 “autoload” 模式支持多种标准和技术。

PSR-0 是旧的自动加载标准,已弃用,但仍支持我们应该避免使用它。

PSR-4 是现代自动加载标准,取代了 PSR-0。它是命名空间类的主要自动加载标准。

classmap 是用于加载没有名称空间或名称空间前缀的类的自动加载标准。

files 是加载文件的加载标准。

你可能已经猜到了,files 是我们需要在不定义类的情况下加载 PHP 文件的标准,该类仅包含 helper 方法files 标准接受每个文件的相对路径数组。通常,当你要定义全局助手方法时,最好使用 “functions.PHP” 或 “helpers.PHP名称创建一个 PHP 文件,并将所有助手函数放入其中。

"autoload": {
    "files": [
        "src/functions.PHP"
    ]
}

关于如何编写和自动加载全局函数,有一些常见的做法。你需要记住,由于在 Composer 加载这些函数时没有命名空间,因此它们可能与现有功能冲突。Composer 自动加载机制始终检查给定的函数或类是否已经存在,如果存在,Composer 会引发异常,抛出 “cannot redeclare”。为了避免这种情况,在加载函数之前,我们可以检查它是否可用。

functions.PHP

if (!function_exists('sayHello')) {
    function sayHello()
    {
        return 'Hello!';
    }
}

在此示例中,我们要求 Composer 检查名称为 sayHello 的全局函数是否已存在,如果不存在则加载给定函数,否则将其忽略并使用已可用的函数

推荐教程:《PHP教程》《Composer教程

总结

以上是编程之家为你收集整理的PHP使用Composer进行注册全局函数全部内容,希望文章能够帮你解决PHP使用Composer进行注册全局函数所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

PHP相关文章

php中有以下五种方法来检测变量是否为空,那么这五种方法之间有什么区别呢?下面我们就来一起看看吧。1、isset功能:判断变量是否被初始化说明:它并不会判断变量是否为空,可以用来判断数组中元素是否被定义过。
字符串函数 strlen:获取字符串的长度,获取的是字符串的字节长度 字符:一个完整的符号,a,中 字节:由8位组成 一个字符最少等于一个字节:ASCII码,a,b,通常英文字符都是占用一个字节 中文在gbk或者gb2312编码里,占用两个字节 中文在utf-8里最少占用3个字节,有可能是4个字节 substr:截取字符串,以字节为单位截取 string sub...
数据的操作无外乎就是对数据的增删改查增加数据基本方式:insert into 表名 [(字段列表)] values (值列表);主键冲突:在插入数据的时候,主键值已经存在了,但是要求是必须使用该主键字段 实现目标:如果该主键不存在那么就增加记录,如果存在,就修改部分字段的值1.使用主键冲突方式语法:insert into 表名 values(值列表) on dup...
范式:Normal Format规定的一种设计方式范式特点:范式有很多,从低级到高级有六级左右,低级往高级一级比一级要求严格。关系型数据库通常设计只需要满足其中一半,满足第三范式即可。满足第三范式必须先满足第二范式,第二范式又必须先满足第一范式。第一范式:1NF数据表的设计的字段中,每个字段都不能再分,每个字段都必须是最小的不可分割的单位(原子性) 讲师代课表 要知...
在字段类型之后,用于对当前字段进行一系列的约束的内容(限制内容的情况) 字段属性:null/not null,primary key,auto_increment,unique key,comment,defaultnull表示字段的值可以为空(在进行数据插入的时候,该字段可以不给数据),not null表示不能为空,必须要给定值(不能是null)default默...
mysql中也分为三大数据类型:数值型,字符型,时间日期型 数值型数值型分为整数型和小数型(包含小数部分的数据类型)整型mysql中光整数型数据类型就有五种:tinyint,smallint,mediumint,int,bigint tinyint:迷你整型,占用1个字节保存数据,能够表示256个数值 smallint:小整型,占用2个字节保存数据,能够表示6...
校对集就是数据库数据进行比较的时候所采用的比较方式。 A =======> 01000001 =======> 65 a =======> 01100001 ========> 97校对集有三种比较方式 _bin:使用二进制进行比较(区分大小写) _ci:(case insensitive),大小写不敏感,不区分大小写(将某个字符转变成...
1.mytable1存储的数据是utf8字符集(在创建表的时候,指定了表的数据存储字符集为utf8)2.cmd控制台只能是gbk格式的数据:说明cmd下只能输入和显示gbk格式的数据3.set names gbk的功能 客户端与服务端进行不同编码的通信的原理 了解数据库的字符集 查看数据库支持哪些字符集?show character set; mysql支持39种字...
微信公众号搜索 “ 程序精选 ” ,选择关注!
微信公众号搜 "程序精选"关注