PHPerKaigi 2025

spl_autoload_extensions

(PHP 5 >= 5.1.0, PHP 7, PHP 8)

spl_autoload_extensions Enregistre et retourne l'extension du fichier par défaut pour spl_autoload

Description

spl_autoload_extensions(?string $file_extensions = null): string

Cette fonction peut modifier et vérifier les extensions de fichiers pour __autoload() la fonction interne de secours que spl_autoload() utilisera.

Note: Il ne devrait pas y avoir d'espaces entre les extensions de fichiers définies.

Liste de paramètres

file_extensions

Si null, elle retourne simplement la liste courante des extensions, séparées par une virgule. Pour modifier cette liste, appelez simplement la fonction avec la nouvelle liste d'extensions à utiliser dans une chaîne de caractères, dont chaque extension sera séparée par une virgule.

Valeurs de retour

Une liste d'extensions de fichiers, délimitées par des virgules, pour spl_autoload().

Historique

Version Description
8.0.0 file_extensions est désormais nullable.

Exemples

Exemple #1 Exemple avec spl_autoload_extensions()

<?php
spl_autoload_extensions
(".php,.inc");
?>
add a note

User Contributed Notes 2 notes

up
6
dantedantas at gmail dot com
7 years ago
The order of the extensions influence the velocity of the reply. For example:

spl_autoload_extensions(".php, .inc");

is more fast than:

spl_autoload_extensions(".inc, .php");

Check out this example:

Some class files:

ClassA.php
<?php class ClassA { var $val = 'Hello from class "ClassA"'; } ?>
ClassB.php
<?php class ClassB { var $val = 'Hello from class "ClassB"'; } ?>
ClassC.php
<?php class ClassC { var $val = 'Hello from class "ClassC"'; } ?>
ClassD.php
<?php class ClassD { var $val = 'Hello from class "ClassD"'; } ?>
ClassE.php
<?php class ClassE { var $val = 'Hello from class "ClassE"'; } ?>

1. Simple:
<?php
// default priority: .inc .php
for($n=65; $n<70; $n++) {
$className = 'Class'.chr($n);
spl_autoload($className);
$ins = new $className;
echo
$ins->val.'<br>';
}
// 4.2 miliseconds
?>

2. Change priority:
<?php
spl_autoload_extensions
('.php,.inc');
// new priority: .php .inc
for($n=65; $n<70; $n++) {
$className = 'Class'.chr($n);
spl_autoload($className);
$ins = new $className;
echo
$ins->val.'<br>';
}
// 1.4 miliseconds
?>
up
3
pim dot stoit at gmail dot com
8 years ago
Extensions doesn't have to start with a dot, spl_autload() will simply append whatever you supply to the basename. The following example will try to load "test.php" first, and "test/index.php" as well:

spl_autoload_register('.php,/index.php');
spl_autoload('Test');
To Top