目錄
PHP中单引号和双引号的区别,php引号双引号
首頁 php教程 php手册 PHP中单引号和双引号的区别,php引号双引号

PHP中单引号和双引号的区别,php引号双引号

Jun 17, 2016 am 08:51 AM
單引號

PHP中单引号和双引号的区别,php引号双引号

1、定义字符串    
在PHP中,字符串的定义可以使用单引号,也可以使用双引号。但是必须使用同一种单或双引号来定义字符串,如:‘Hello"和“Hello'为非法的字符串定义。    
定义字符串时,只有一种引号被视为定义符,即单引号或双引号。于是,如果一个字符串由双引号开始,那么只有双引号被分析器解析。这样,你就可以在双引号串中包含任何其他字符,甚至单引号。下面的引号串都是合法的: 

Php代码 

$s = "I am a 'single quote string' inside a double quote string"; 

$s = 'I am a "double quote string" inside a single quote string'; 

$s = "I am a 'single quote string' inside a double quote string"; 

$s = 'I am a "double quote string" inside a single quote string';    

而串 "Why doesn't "this" work?" 则会被分为三段。如果在这个串中想要表示出双引号,则可以使用转义符"\"(反斜线),变成 "Why doesn't \"this\" work?" 即可。 

2、字符串变量中的单、双引号    

PHP允许我们在双引号串中直接包含字串变量,我们可以发现下面的两个字串的处理结果是相同的。 

$full_name = $first_name . ' ' . $last_name; 

$full_name = "$first_name $last_name";    

单引号串和双引号串在PHP中的处理是不相同的。双引号串中的内容可以被解释而且替换,而单引号串中的内容总被认为是普通字符。例如: 

Php代码 

$foo = 2; 

echo "foo is $foo"; // 打印结果: foo is 2 

echo 'foo is $foo'; // 打印结果: foo is $foo 

echo "foo is $foo\n"; // 打印结果: foo is 2 (同时换行) 

echo 'foo is $foo\n'; // 打印结果: foo is $foo\n 

$foo = 2; 

echo "foo is $foo"; // 打印结果: foo is 2 

echo 'foo is $foo'; // 打印结果: foo is $foo 

echo "foo is $foo\n"; // 打印结果: foo is 2 (同时换行) 

echo 'foo is $foo\n'; // 打印结果: foo is $foo\n    

正如你所看到的,在单引号串中甚至反斜杠也失去了他的扩展含义(除了插入反斜杠\\和插入单引号\')。所以,当你想在字串中进行变量代换和包 含\n(换行符)等转义序列时,你应该使用双引号。单引号串可以用在其他任何地方,脚本中使用单引号串处理速度会更快些,因为PHP语法分析器对单引号串 的处理方式比较单纯,而双引号的处理由于串内部也需要解析,因此更复杂些,所以处理速度略慢。    

在字符串中引用复杂的变量组合时,可能会产生一些问题,下面的代码会正常工作: 

Php代码 

echo "value = $foo"; 

echo "value = $a[$i]"; 

echo "value = $foo"; 

echo "value = $a[$i]";    

而下面的代码却不能得到我们希望的结果: 

echo "value = $a[$i][$j]"; //我们希望打印二维数组$a的某个元素。    

为避免这些字串使用中的潜在问题,我们通常把复杂的变量从字串中分离开来,就像这样:echo 'value = ' . $a[$i][$j];//字符串的连接用点(.)    

还有一种办法是将复杂变量用花括号括起来,语法分析器就能正确辨认了: 

echo "value = {$a[$i][$j]}" //打印二维数组$a的某个元素    

这样,又出现新问题了。当我们想在字串中引用花括号字符本身时,就要记得使用转义符了: 

Php代码 

$var = 3; 

echo "value = {$var}"; // 打印结果 "value = 3" 

echo "value = \{$var}"; // 打印结果 "value = {3}" 

$var = 3; 

echo "value = {$var}"; // 打印结果 "value = 3" 

echo "value = \{$var}"; // 打印结果 "value = {3}" 

3、在SQL语句中    

这是会经常遇到的问题,在插入数据库的SQL语句是采用单引号来定义字符串,如果要将一个含有单引号的字符串插入数据库,这个SQL语句就会出错。 

如:$sql="insert into userinfo (username,password) Values('O'Kefee','123456')"    

此时,处理的方法之一是在SQL语句中加入转义符反斜线, 

即:……Values('O\'Kefee',……    

当然也可以使用函数 addslashes(),该函数的功能就是加入转义符, 

即:$s = addslashes("O'Kefee") ……Values('".$s."',……    

还有一种方法是设置php.ini中的magic-quotes选项,打开该选项,则通过表单提交的信息中如果有单引号是,将会自动加上如转义符。因此不用使用其他函数了。 

补充: 这就要从双引号和单引号的作用讲起: 双引号里面的字段会经过编译器解释然后再当作HTML代码输出,但是单引号里面的不需要解释,直接输出。 

例如: 

$abc='I love u'; 

echo $abc //结果是:I love u 

echo '$abc' //结果是:$abc 

echo "$abc" //结果是:I love u 

所以在对数据库里面的SQL语句赋值的时候也要用在双引号里面SQL="select a,b,c from ..." 但是SQL语句中会有单引号把字段名引出来 

例如:select * from table where user='abc'; 

这里的SQL语句可以直接写成SQL="select * from table where user='abc'" 

但是如果象下面: 

$user='abc'; 

SQL1="select * from table where user=' ".$user." ' ";对比一下 

SQL2="select * from table where user=' abc ' " 

我把单引号和双引号之间多加了点空格,希望你能看的清楚一点。 

也就是把'abc' 替换为 '".$user."'都是在一个单引号里面的。只是把整个SQL字符串分割了。 SQL1可以分解为以下3个部分 

1:"select * from table where user=' " 

2:$user 

3:" ' " 

字符串之间用 . 来连接,这样能明白了吧。 

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1665
14
CakePHP 教程
1424
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24