php单引号和双引号的区别.doc

上传人:新** 文档编号:544790326 上传时间:2023-11-15 格式:DOC 页数:8 大小:38.50KB
返回 下载 相关 举报
php单引号和双引号的区别.doc_第1页
第1页 / 共8页
php单引号和双引号的区别.doc_第2页
第2页 / 共8页
php单引号和双引号的区别.doc_第3页
第3页 / 共8页
php单引号和双引号的区别.doc_第4页
第4页 / 共8页
php单引号和双引号的区别.doc_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《php单引号和双引号的区别.doc》由会员分享,可在线阅读,更多相关《php单引号和双引号的区别.doc(8页珍藏版)》请在金锄头文库上搜索。

1、“单引号和双引号的区别和用法?”现将答案总结了下,写成这篇小短文。 双引号里面的字段会经过编译器解释,然后再当作HTML代码输出。 单引号里面的不进行解释,直接输出。 例如: $abc=my name is tome; echo $abc /结果是:my name is tom echo $abc /结果是:$abc echo $abc /结果是:my name is tom 特别在使用MYSQL语句的时候,双引号和单引号的用法让新手不知所措,在这里,举个例子,来进行说明。 假设查询条件中使用的是常量,例如: select * from abc_table where user_name=ab

2、c; SQL语句可以写成: SQLstr = select * from abc_table where user _name= abc ; 假设查询条件中使用的是变量,例如: $user_name = $_REQUESTuser_name; /字符串变量 或 $user=array (name= $_REQUESTuser_name,age=$_REQUESTage;/数组变量 SQL语句就可以写成: SQLstr = select * from abc_table where user_name = . $user_name . ; SQLstr = select * from abc_t

3、able where user_name = . $username . ; 对比一下: SQLstr=select * from abc_table where user_name = abc ; SQLstr=select * from abc_table where user_name = . $user _name . ; SQLstr=select * from abc_table where user_name = . $username . ; SQLstr可以分解为以下3个部分: 1:select * from table where user_name = /固定SQL语句

4、2:$user /变量 3: 1,2,3部分字符串之间用. 来连接 一、引号定义字符串在PHP中,通常一个字符串被定义在一对引号中,如:I am a string in single quotesI am a string in double quotesPHP语法分析器是用成对的引号来判断一个字符串的。因此,所有字符串必须使用同一种单或者双引号来定义开始和结束。例如,下面的字串定义是不合法的:I am not a valid string since I have unmatching quote marksMe neither!定义字符串时,只有一种引号被视为定义符,即单引号或双引号。于是

5、,如果一个字符串由双引号开始,那么只有双引号被分析器解析。这样,你就可以在双引号串中包含任何其他字符,甚至单引号。下面的引号串都是合法的:$s = I am a single quote string inside a double quote string;$s = I am a double quote string inside a single quote string;当PHP遇到与串的开头相对应的引号时,便认为已经到了字符串尾部,于是:Why doesnt this work?实际上被PHP语法分析器分成三个部分:Why doesnt 包含一个单引号的双引号串this多余的字符,分

6、析器无法处理 work? 普通字符串上面的这个例子企图在双引号串中包含双引号,而分析器在遇到第二个双引号时便认为字符串结束了。要达到包含引号的目的,必须分析器在遇到串内普通引号的时候忽略它的原意,我们在引号的前面加上一个反斜杠来告诉PHP:这个引号是字符串的一部分,正确的表示方法是这样:Why doesnt that work?在英文字符串中一个常见的问题是撇号的使用,因为它就是一个单引号,而在英文串中十分常见(英文所有格)。你必须小心处理这些字符:Youd better escape your apostrophes可以看到反斜杠在字符串中有他的特殊含义,当我们需要在字符串中包含反斜杠本身时

7、,需要在该符号前面多加一个反斜杠。例如:$file = c:windowssystem.ini;echo $file; / 打印结果为: c:windowssystem.ini$file = c:windowssystem.ini;echo $file; / 打印结果为: c:windowssystem.ini另一种字符串定义方式,能够消除特殊字符的烦恼,而且便于引用较长的文本。该字符串定义方法以符号紧跟一个自定义字符串开头,最后一行以该自定义字符串结束,并且必须顶格。二、字串的连接字串可以使用字串连接符(.)来连接,如:$first_name = Charlie;$last_name = B

8、rown;$full_name = $first_name . . $last_name;常见的用途是建立大块的HTML字串代码,赋值号 (=) 连接符 (.) 可以被简写合并为 (.=) 符号,如:$html = ;$html .= numbersquare;for ( $i=0 ; $i10 ; $i+) $square = $i * $i;$html .= . $i . . $square . ;$html .= ;三、在字串中使用变量这个功能让你无须使用连接符号来粘和大量的简单字符串。PHP允许我们在双引号串中直接包含字串变量,我们可以发现下面的两个字串的处理结果是相同的。$full_

9、name = $first_name . . $last_name;$full_name = $first_name $last_name;单引号串和双引号串在PHP中的处理是不相同的。双引号串中的内容可以被解释而且替换,而单引号串中的内容总被认为是普通字符。例如:$foo = 2;echo foo is $foo; / 打印结果: foo is 2echo foo is $foo; / 打印结果: foo is $fooecho foo is $foon; / 打印结果: foo is 2 (同时换行)echo foo is $foon; / 打印结果: foo is $foon正如你所看到

10、的,在单引号串中甚至反斜杠也失去了他的扩展含义(除了插入反斜杠和插入单引号)。所以,当你想在字串中进行变量代换和包含n(换行符)等转义序列时,你应该使用双引号。单引号串可以用在其他任何地方,脚本中使用单引号串处理速度会更快些,因为PHP语法分析器对单引号串的处理方式比较单纯,而双引号的处理由于串内部也需要解析,因此更复杂些,所以处理速度略慢。在字符串中引用复杂的变量组合时,可能会产生一些问题,下面的代码会正常工作:echo value = $foo;echo value = $a$i;而下面的代码却不能得到我们希望的结果:echo value = $a$i$j; /我们希望打印二维数组$a的某

11、个元素。为避免这些字串使用中的潜在问题,我们通常把复杂的变量从字串中分离开来,就像这样:echo value = . $a$i$j;还有一种办法是将复杂变量用花括号括起来,语法分析器就能正确辨认了:echo value = $a$i$j /打印二维数组$a的某个元素这样,又出现新问题了。当我们想在字串中引用花括号字符本身时,就要记得使用转义符了:$var = 3;echo value = $var; / 打印结果 value = 3echo value = $var; / 打印结果 value = 3三、斜杠和SQL语句生成HTML代码或SQL查询语句是编写PHP程序时经常遇到而且是件有趣的事

12、情。为什么这么说呢,因为这涉及到生成另外一种类型的代码,你必须仔细地考虑和遵循这种代码所要求的编写语法和规则。我们来看这样一个例子,假如你想查询数据库中名字是“OKeefe”的用户,通常SQL语句的形式是这样的:select * from users where last_name = OKeefe请注意SQL语句这个英文所有格(撇号)需使用反斜杠转义。PHP专门提供了一些函数来处理这样的情况,函数AddSlashes($str)的用途就是自动在字串中对引号字符插入反斜杠转义符:$last_name = OKeefe;$sql = select * from users where last_

13、name = . addslashes($last_name) . ;在这个例子中,你还要在last_name字串外面括上单引号(SQL语法要求),由于这里使用的是双引号串,所以对这对单引号就无须使用转义了。下面的这个语句是使用单引号串的等价形式:$sql = select * from users where last_name = . addslashes($last_name) . ;任何时候你要在数据库中写入字串,你都必须确保里面的引号正确使用了转义符号,这是很多PHP初学者常犯的错误。四、双引号和HTML与SQL语句不同,在标准HTML语言中双引号常被用来表示字串(现在很多浏览器具备较强的容错功能,允许在HTML中用单引号甚至不用引号表示字符串),例如:$html = .$link.;$html = $link;HTML语言不支持反斜杠转义,这一点在我们使用表单的hidden inputs来传输数据的时候就会有所体会了。设置hidden inputs的值的最好办法,是使用htmlspecialchars()函数来编码。下面的语句可以正常传输一个可能包含双引号的数据:in

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号