我想知道,插入PHP变量到字符串的正确方法是什么? 这种方式:

echo "Welcome ".$name."!"

或者这样:

echo "Welcome $name!"

这两种方法都可以在我的PHP v5.3.5中使用。后者更短更简单,但我不确定前者是更好的格式还是更合适。


当前回答

从简单、易读、一致和易于理解的角度来看(因为性能在这里并不重要):

Using embedded vars in double quotes can lead to complex and confusing situations when you want to embed object properties, multidimentional arrays etc. That is, generally when reading embedded vars, you cannot be instantly 100% sure of the final behavior of what you are reading. You frequently need add crutches such as {} and \, which IMO adds confusion and makes concatenation readability nearly equivalent, if not better. As soon as you need to wrap a function call around the var, for example htmlspecialchars($var), you have to switch to concatenation. AFAIK, you cannot embed constants.

在某些特定情况下,“嵌入vars的双引号”可能是有用的,但一般来说,我会使用串联(方便时使用单引号或双引号)

其他回答

我知道这个问题已经有了一个选择的答案,但我发现这篇文章明显表明,字符串插值比串联更快。这可能对那些仍在犹豫的人有所帮助。

不要连接。这是不需要的,我们的逗号作为echo可以接受多个参数

echo "Welcome ", $name, "!";

关于使用单引号或双引号,差异可以忽略不计,您可以使用大量字符串进行测试。

我一直都喜欢这种方式,而且发现它容易得多。

echo "Welcome {$name}!"
echo "Welcome $name!";

这是最好的办法。

你不需要其他任何东西

在这两种语法之间,你应该选择一个你喜欢的:-)

就我个人而言,在这种情况下,我会选择你的第二个解决方案(变量插值),我发现它更容易写和读。

结果是一样的;即使对性能有影响,那也不重要。

作为旁注,所以我的回答更完整一点:那天你会想做这样的事情:

echo "Welcome $names!";

PHP会将您的代码解释为您试图使用$names变量——这个变量并不存在。 -注意,只有在字符串中使用" not "时它才会起作用。

那天,你需要使用{}:

echo "Welcome {$name}s!"

不需要退回到连接。

还要注意你的第一个语法:

echo "Welcome ".$name."!";

可以优化,避免连接,使用:

echo "Welcome ", $name, "!";

(但是,就像我之前说的,这并不重要…)

1 -除非你在做成千上万次的拼接和插值——这可能不是完全的情况。