PHP句法规则详解,php句法详解
PHP句法规则详解,php句法详解
1.简单句法规则(用花括号界定变量名,适用于PHP所有版本):
<span class="pln">$a <span class="pun">=<span class="str">'flower'<span class="pun">;<span class="pln"> echo <span class="str">"She received some $as"<span class="pun">;<span class="com">// 无效;字母s会被当成有效的变量名组成元素,但是这里的变量是$a<span class="pln"> echo <span class="str">"She received some ${a}s"<span class="pun">;<span class="com">// 有效<span class="pln"> echo <span class="str">"She received some {$a}s"<span class="pun">;<span class="com">// 有效;推荐的使用方法</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
我们希望表达的是”她收到一些花“,语境中的flower应该采用复数形式(也就是说应该在后面加上S),但是如果不对变量做任何界定的话,就会出现第一个echo的情况。显然我们希望输出的是$a而不是$as。那么我们通常是怎么来处理这个输出的呢?
<span class="pln">echo <span class="str">"She received some $a"<span class="pun">.<span class="str">"s"<span class="pun">;<span class="pln"> echo <span class="str">"She received some "<span class="pun">.<span class="pln">$a<span class="pun">.<span class="str">"s"<span class="pun">;<span class="com">// 这两种习惯性的写法应该没有加花括号的写法简洁明了吧?</span></span></span></span></span></span></span></span></span></span></span></span></span>
注意:不管{是出现在$前面还是后面,只有两者紧挨着时花括号才会被当成是界定符号。不要在之间加空格,要不然就会被当作普通的花括号处理
<span class="pln">echo <span class="str">"She received some { $a}s"<span class="pun">;<span class="com">// 输出的结果为:She received some { flower}s</span></span></span></span>
2.复杂句法规则(用花括号界定表达式等,使用与PHP4+):
<span class="pln">echo <span class="str">"有效的写法: {$arr[4][3]}"<span class="pun">;<span class="com">// 有效;界定多维数组<span class="pln"> echo <span class="str">"有效的写法: {$arr['foo'][3]}"<span class="pun">;<span class="com">// 有效;当在字符串中使用多维数组时,一定要用括号将它括起来<span class="pln"> echo <span class="str">"有效的写法: {$this->width}00"<span class="pun">;<span class="com">// 有效;如果不界定的话,就会变成 $this->width00<span class="pln"> echo <span class="str">"有效的写法: {$this->value[3]->name}"<span class="pun">;<span class="com">// 有效;该例演示了界定链式调用<span class="pln"> echo <span class="str">"有效的写法: $name: {${$name}}"<span class="pun">;<span class="com">// 有效;该例演示的效果实际上是一个可变变量<span class="pln"> echo <span class="str">"有效的写法: {${getName()}}"<span class="pun">;<span class="com">// 有效;该例演示了将函数的返回值作为变量名<span class="pln"> echo <span class="str">"有效的下发: {${$this->getName()}}"<span class="pun">;<span class="com">// 有效;该例演示了将函数的返回值作为变量名</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
注意1:echo "这样写有效吗: {getName()}";输出结果为:'这样写有效吗:
{getName()}'。因为里面不含$,所以花括号不会被当作界定符
注意2:echo "这样写有效吗:{$arr[foo][3]}"; 在回答这个问题前我们先来进行一个实验:
<span class="pln">error_reporting<span class="pun">(<span class="pln">E_ALL<span class="pun">);<span class="pln"> $arr <span class="pun">=<span class="pln"> array<span class="pun">(<span class="str">'a'<span class="pun">,<span class="str">'b'<span class="pun">,<span class="str">'c'<span class="pun">,<span class="str">'d'<span class="pun">=><span class="str">'e'<span class="pun">);<span class="pln"> echo <span class="str">"This is $arr[d]"<span class="pun">;<span class="com">// 我们发现这样写是没有问题的,那么我们像下面这样写呢?<span class="pln"> echo $arr<span class="pun">[<span class="pln">d<span class="pun">];</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
产生了这样的错误:
Notice: Use of undefined constant d - assumed 'd'
注意:采用了未定义的常量d,可能应该为'd'
那么如果我们像下面这样修改一下代码的话
<span class="pln">error_reporting<span class="pun">(<span class="pln">E_ALL<span class="pun">);<span class="pln"> $arr <span class="pun">=<span class="pln"> array<span class="pun">(<span class="str">'a'<span class="pun">,<span class="str">'b'<span class="pun">,<span class="str">'c'<span class="pun">,<span class="str">'d'<span class="pun">=><span class="str">'e'<span class="pun">);<span class="pln"> define<span class="pun">(<span class="str">'f'<span class="pun">,<span class="str">'d'<span class="pun">);<span class="pln"> echo $arr<span class="pun">[<span class="pln">f<span class="pun">];</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
我们发现这次没有问题了。可以看出在字符串中数组的索引不加单引号是没有问题的,但是如果这种写法不是出现在字符串当中就会报错,而对于字符串中 {$arr[foo][3]}的解析就是按照非字符串的方式解析的。所以说在字符串当中对数组只加花括号界定而不对索引加单引号的写法是错误的。因为程序 会把不加单引号的索引当作是常量来进行解析,这就产生了错误。正确的写法应该是:
<span class="pln">echo <span class="str">"有效的写法: {$arr['foo'][3]}"<span class="pun">;</span></span></span>
特别提醒一点:echo "This is $arr[d]";这种写法虽然能够被程序解析,但这也仅限于数组是一维数组的情况。严谨的写法应该是:echo "This is {$arr['d']}";我的学生曾经在这一点上和我争论过,他说:既然前面一种写法能出结果,为什么一定要用后面一种写法呢?那么,我们再继续修改一 下前面的代码
<span class="pln">error_reporting<span class="pun">(<span class="pln">E_ALL<span class="pun">);<span class="pln"> $arr <span class="pun">=<span class="pln"> array<span class="pun">(<span class="str">'a'<span class="pun">,<span class="str">'b'<span class="pun">,<span class="str">'c'<span class="pun">,<span class="str">'d'<span class="pun">=><span class="pln">array<span class="pun">(<span class="str">'e'<span class="pun">=><span class="str">'f'<span class="pun">)<span class="pun">);<span class="pln"> echo <span class="str">"This is $arr[d][e]"<span class="pun">;</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
这样还能够被正确解析吗?我只想告诉你,加花括号是严谨的必要的。当然,如果你不是我的学生那么我管不了那么多......
注意3:
<span class="pln">error_reporting<span class="pun">(<span class="pln">E_ALL<span class="pun">);<span class="pln"> $arr <span class="pun">=<span class="pln"> array<span class="pun">(<span class="str">'a'<span class="pun">,<span class="str">'b'<span class="pun">,<span class="str">'c'<span class="pun">,<span class="str">'d'<span class="pun">);<span class="pln"> echo <span class="str">"This is {$arr[2]} <br />"<span class="pun">;<span class="pln"> echo <span class="str">"This is {$arr['2']} <br />"<span class="pun">;</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
执行上面的代码。结果是一样的,为什么会这样呢?我只能告诉你PHP是弱类型语言,至于什么叫弱类型语言我就不在这里多说了。自己去Google一下吧。说了这么多,那么最能体现这些句法规则优势的具体应用在什么地方呢?----SQL语句
<span class="com">// 示例一:<span class="pln"> $SQL1 <span class="pun">=<span class="str">"select * from table where id={$_GET['id']}"<span class="pun">;<span class="com">// 示例二:<span class="pln"> $SQL2 <span class="pun">=<span class="str">"select * from table where id={$this->id}"<span class="pun">;</span></span></span></span></span></span></span></span></span></span>

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Explication détaillée de la méthode de référence jQuery : Guide de démarrage rapide jQuery est une bibliothèque JavaScript populaire largement utilisée dans le développement de sites Web. Elle simplifie la programmation JavaScript et fournit aux développeurs des fonctions et fonctionnalités riches. Cet article présentera en détail la méthode de référence de jQuery et fournira des exemples de code spécifiques pour aider les lecteurs à démarrer rapidement. Présentation de jQuery Tout d'abord, nous devons introduire la bibliothèque jQuery dans le fichier HTML. Il peut être introduit via un lien CDN ou téléchargé

Comment utiliser la méthode de requête PUT dans jQuery ? Dans jQuery, la méthode d'envoi d'une requête PUT est similaire à l'envoi d'autres types de requêtes, mais vous devez faire attention à certains détails et paramètres. Les requêtes PUT sont généralement utilisées pour mettre à jour des ressources, comme la mise à jour de données dans une base de données ou la mise à jour de fichiers sur le serveur. Ce qui suit est un exemple de code spécifique utilisant la méthode de requête PUT dans jQuery. Tout d'abord, assurez-vous d'inclure le fichier de la bibliothèque jQuery, puis vous pourrez envoyer une requête PUT via : $.ajax({u

jQuery est une bibliothèque JavaScript rapide, petite et riche en fonctionnalités, largement utilisée dans le développement front-end. Depuis sa sortie en 2006, jQuery est devenu l'un des outils de choix pour de nombreux développeurs, mais dans les applications pratiques, il présente également certains avantages et inconvénients. Cet article analysera en profondeur les avantages et les inconvénients de jQuery et l'illustrera avec des exemples de code spécifiques. Avantages : 1. Syntaxe concise La conception syntaxique de jQuery est concise et claire, ce qui peut grandement améliorer la lisibilité et l'efficacité d'écriture du code. Par exemple,

Comment supprimer l'attribut height d'un élément avec jQuery ? Dans le développement front-end, nous rencontrons souvent le besoin de manipuler les attributs de hauteur des éléments. Parfois, nous pouvons avoir besoin de modifier dynamiquement la hauteur d'un élément, et parfois nous devons supprimer l'attribut height d'un élément. Cet article explique comment utiliser jQuery pour supprimer l'attribut height d'un élément et fournit des exemples de code spécifiques. Avant d'utiliser jQuery pour exploiter l'attribut height, nous devons d'abord comprendre l'attribut height en CSS. L'attribut height est utilisé pour définir la hauteur d'un élément

Titre : jQuery Astuces : Modifier rapidement le texte de toutes les balises a de la page En développement web, nous avons souvent besoin de modifier et d'exploiter des éléments de la page. Lorsque vous utilisez jQuery, vous devez parfois modifier le contenu textuel de toutes les balises de la page en même temps, ce qui peut économiser du temps et de l'énergie. Ce qui suit explique comment utiliser jQuery pour modifier rapidement le texte de toutes les balises a de la page et donne des exemples de code spécifiques. Tout d'abord, nous devons introduire le fichier de la bibliothèque jQuery et nous assurer que le code suivant est introduit dans la page : <

Titre : utilisez jQuery pour modifier le contenu textuel de toutes les balises. jQuery est une bibliothèque JavaScript populaire largement utilisée pour gérer les opérations DOM. En développement web, nous rencontrons souvent le besoin de modifier le contenu textuel de la balise de lien (une balise) sur la page. Cet article expliquera comment utiliser jQuery pour atteindre cet objectif et fournira des exemples de code spécifiques. Tout d’abord, nous devons introduire la bibliothèque jQuery dans la page. Ajoutez le code suivant dans le fichier HTML :

jQuery est une bibliothèque JavaScript populaire largement utilisée pour gérer la manipulation DOM et la gestion des événements dans les pages Web. Dans jQuery, la méthode eq() est utilisée pour sélectionner des éléments à une position d'index spécifiée. Les scénarios d'utilisation et d'application spécifiques sont les suivants. Dans jQuery, la méthode eq() sélectionne l'élément à une position d'index spécifiée. Les positions d'index commencent à compter à partir de 0, c'est-à-dire que l'index du premier élément est 0, l'index du deuxième élément est 1, et ainsi de suite. La syntaxe de la méthode eq() est la suivante : $("s

Comment savoir si un élément jQuery possède un attribut spécifique ? Lorsque vous utilisez jQuery pour exploiter des éléments DOM, vous rencontrez souvent des situations dans lesquelles vous devez déterminer si un élément possède un attribut spécifique. Dans ce cas, nous pouvons facilement implémenter cette fonction à l'aide des méthodes fournies par jQuery. Ce qui suit présentera deux méthodes couramment utilisées pour déterminer si un élément jQuery possède des attributs spécifiques et joindra des exemples de code spécifiques. Méthode 1 : utilisez la méthode attr() et l'opérateur typeof // pour déterminer si l'élément a un attribut spécifique
