Home Backend Development PHP Tutorial Detailed explanation of PHP syntax rules

Detailed explanation of PHP syntax rules

Nov 24, 2016 pm 01:16 PM

  1. Simple syntax rules (delimit variable names with braces, applicable to all versions of PHP):

1

2

3

4

5

$a = 'flower';

echo "She received some $as";

// 无效;字母s会被当成有效的变量名组成元素,但是这里的变量是$a

echo "She received some ${a}s"; // 有效

echo "She received some {$a}s"; // 有效;推荐的使用方法

Copy after login

What we want to express is "she received some flowers", and the word "flower" in the context should be in the plural form (also That is to say, S) should be added at the end, but if the variables are not defined in any way, the first echo will occur. Obviously we want the output to be $a rather than $as. So how do we usually process this output?

1

2

echo "She received some $a"."s";

echo "She received some ".$a."s";

Copy after login

These two customary ways of writing should be less concise and clear than the way of writing with curly brackets, right?
Note: No matter whether { appears before or after $, curly braces will be regarded as delimiting symbols only when the two are immediately adjacent. Do not add spaces between them, otherwise they will be treated as ordinary curly braces

1

2

echo "She received some { $a}s";

// 输出的结果为:She received some { flower}s

Copy after login

2. Complex syntax rules (using curly braces to define expressions, etc., used with PHP4+):

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

echo "有效的写法: {$arr[4][3]}";

// 有效;界定多维数组

echo "有效的写法: {$arr['foo'][3]}";

// 有效;当在字符串中使用多维数组时,一定要用括号将它括起来

echo "有效的写法: {$this->width}00";

// 有效;如果不界定的话,就会变成 $this->width00

echo "有效的写法: {$this->value[3]->name}"

// 有效;该例演示了界定链式调用

echo "有效的写法: $name: {${$name}}";

// 有效;该例演示的效果实际上是一个可变变量

echo "有效的写法: {${getName()}}";

// 有效;该例演示了将函数的返回值作为变量名

echo "有效的下发: {${$this->getName()}}";

// 有效;该例演示了将函数的返回值作为变量名

注意1:echo "这样写有效吗: {getName()}";输出结果为:'这样写有效吗:

{getName()}'。因为里面不含$,所以花括号不会被当作界定符

注意2:echo "这样写有效吗:{$arr[foo][3]}"; 在回答这个问题前我们先来进行一个实验:

error_reporting(E_ALL);

$arr = array('a', 'b', 'c', 'd'=>'e');

echo "This is $arr[d]";

// 我们发现这样写是没有问题的,那么我们像下面这样写呢?

echo $arr[d];

Copy after login

produced such an error:
Notice: Use of undefined constant d - assumed 'd'
Note: An undefined constant d is used, which should probably be 'd'
So if we modify the code as follows

1

2

3

4

error_reporting(E_ALL);

$arr = array('a', 'b', 'c', 'd'=>'e');

define('f', 'd');

echo $arr[f];

Copy after login

We find that there is no problem this time . It can be seen that there is no problem if the index of the array in the string is not enclosed in single quotes, but if this writing method does not appear in the string, an error will be reported, and for {$arr[foo][3]} in the string Parsing is based on non-string parsing. Therefore, it is wrong to only add curly braces to delimit the array in the string without adding single quotes to the index. Because the program will parse the index without single quotes as a constant, this generates an error. The correct way of writing should be:
echo "Effective way of writing: {$arr['foo'][3]}";
A special reminder: echo "This is $arr[d]"; Although this way of writing can be used by the program parsing, but this is limited to the case where the array is a one-dimensional array. The rigorous writing method should be: echo "This is {$arr['d']}"; My student once argued with me on this point. He said: Since the previous writing method can produce results, why must we use it? What about the latter way of writing? So, let’s continue to modify the previous code

1

2

3

4

5

error_reporting(E_ALL);

$arr = array('a', 'b', 'c',

'd'=>array('e'=>'f')

);

echo "This is $arr[d][e]";

Copy after login

Can it still be parsed correctly? I just want to tell you that adding curly braces is strictly necessary. Of course, if you are not my student, then I can’t control that much...

Note 3:

1

2

3

4

error_reporting(E_ALL); 

$arr = array('a', 'b', 'c', 'd'); 

echo "This is {$arr[2]} <br />"

echo "This is {$arr[&#39;2&#39;]} <br />";

Copy after login


Execute the above code. The result is the same, why is this? I can only tell you that PHP is a weakly typed language. As for what a weakly typed language is, I won’t say more here. Go Google it yourself. Having said so much, where are the specific applications that best reflect the advantages of these syntactic rules? ----SQL statement

Java code

1

2

3

4

// 示例一: 

$SQL1 = "select * from table where id={$_GET[&#39;id&#39;]}"

// 示例二: 

$SQL2 = "select * from table where id={$this->id}";

Copy after login


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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Apr 05, 2025 am 12:04 AM

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

How does session hijacking work and how can you mitigate it in PHP? How does session hijacking work and how can you mitigate it in PHP? Apr 06, 2025 am 12:02 AM

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.

Describe the SOLID principles and how they apply to PHP development. Describe the SOLID principles and how they apply to PHP development. Apr 03, 2025 am 12:04 AM

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

How to debug CLI mode in PHPStorm? How to debug CLI mode in PHPStorm? Apr 01, 2025 pm 02:57 PM

How to debug CLI mode in PHPStorm? When developing with PHPStorm, sometimes we need to debug PHP in command line interface (CLI) mode...

How to automatically set permissions of unixsocket after system restart? How to automatically set permissions of unixsocket after system restart? Mar 31, 2025 pm 11:54 PM

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

Explain late static binding in PHP (static::). Explain late static binding in PHP (static::). Apr 03, 2025 am 12:04 AM

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

How to send a POST request containing JSON data using PHP's cURL library? How to send a POST request containing JSON data using PHP's cURL library? Apr 01, 2025 pm 03:12 PM

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

See all articles