我想知道,插入PHP变量到字符串的正确方法是什么? 这种方式:
echo "Welcome ".$name."!"
或者这样:
echo "Welcome $name!"
这两种方法都可以在我的PHP v5.3.5中使用。后者更短更简单,但我不确定前者是更好的格式还是更合适。
我想知道,插入PHP变量到字符串的正确方法是什么? 这种方式:
echo "Welcome ".$name."!"
或者这样:
echo "Welcome $name!"
这两种方法都可以在我的PHP v5.3.5中使用。后者更短更简单,但我不确定前者是更好的格式还是更合适。
当前回答
在这两种语法之间,你应该选择一个你喜欢的:-)
就我个人而言,在这种情况下,我会选择你的第二个解决方案(变量插值),我发现它更容易写和读。
结果是一样的;即使对性能有影响,那也不重要。
作为旁注,所以我的回答更完整一点:那天你会想做这样的事情:
echo "Welcome $names!";
PHP会将您的代码解释为您试图使用$names变量——这个变量并不存在。 -注意,只有在字符串中使用" not "时它才会起作用。
那天,你需要使用{}:
echo "Welcome {$name}s!"
不需要退回到连接。
还要注意你的第一个语法:
echo "Welcome ".$name."!";
可以优化,避免连接,使用:
echo "Welcome ", $name, "!";
(但是,就像我之前说的,这并不重要…)
1 -除非你在做成千上万次的拼接和插值——这可能不是完全的情况。
其他回答
你应该选择第一个。他们没有什么不同,除了性能,第一个将是最快的第二个比较。
如果双引号内的变量PHP需要时间来解析变量。
检查这个单引号或双引号变量连接?
在php中单引号和双引号是否有性能上的优势?
我不明白为什么上面链接的这个答案会被点赞,为什么这个答案会被点赞。
我也说过了。
你也可以看这里
PHP中哪个更快,单引号还是双引号?
如果你想执行一个SQL命令,而你的变量是数组成员,那么你不应该在数组的[]中使用单引号(像这样:["]);例如,如果你使用这个字符串作为SQL命令,你会得到服务器错误500:
$con = mysqli_connect('ServerName', 'dbUsername', 'dbPassword');
mysqli_select_db($con, 'dbName')
//'ID' is auto increment field.
$sql = "INSERT INTO sampleTable (ID, TraceNo) VALUES ('','$sampleArray['TraceNo']')";
mysqli_query($con, $sql)
正确的字符串是:
//'ID' is auto increment field.
$sql = "INSERT INTO sampleTable (ID, TraceNo) VALUES ('','$sampleArray[TraceNo]')";
我一直都喜欢这种方式,而且发现它容易得多。
echo "Welcome {$name}!"
在这两种语法之间,你应该选择一个你喜欢的:-)
就我个人而言,在这种情况下,我会选择你的第二个解决方案(变量插值),我发现它更容易写和读。
结果是一样的;即使对性能有影响,那也不重要。
作为旁注,所以我的回答更完整一点:那天你会想做这样的事情:
echo "Welcome $names!";
PHP会将您的代码解释为您试图使用$names变量——这个变量并不存在。 -注意,只有在字符串中使用" not "时它才会起作用。
那天,你需要使用{}:
echo "Welcome {$name}s!"
不需要退回到连接。
还要注意你的第一个语法:
echo "Welcome ".$name."!";
可以优化,避免连接,使用:
echo "Welcome ", $name, "!";
(但是,就像我之前说的,这并不重要…)
1 -除非你在做成千上万次的拼接和插值——这可能不是完全的情况。
不要连接。这是不需要的,我们的逗号作为echo可以接受多个参数
echo "Welcome ", $name, "!";
关于使用单引号或双引号,差异可以忽略不计,您可以使用大量字符串进行测试。