What could I use in PHP in place of the normal '
and (without ' or ") symbols around something?
Example:
echo("Hello, World!")
What could I use in PHP in place of the normal '
and (without ' or ") symbols around something?
Example:
echo("Hello, World!")
There are 4 ways to encapsulate strings, single quotes '
, double quotes "
, heredoc and nowdoc.
Read the full php.net article here.
A third way to delimit strings is the heredoc syntax: <<<. After this operator, an identifier is provided, then a newline. The string itself follows, and then the same identifier again to close the quotation.
http://www.php.net/manual/en/language.types.string.php#language.types.string.syntax.heredoc
$str = <<<EOD
Example of string
spanning multiple lines
using heredoc syntax.
EOD;
Nowdocs are to single-quoted strings what heredocs are to double-quoted strings. A nowdoc is specified similarly to a heredoc, but no parsing is done inside a nowdoc. The construct is ideal for embedding PHP code or other large blocks of text without the need for escaping. It shares some features in common with the SGML construct, in that it declares a block of text which is not for parsing.
A nowdoc is identified with the same <<< sequence used for heredocs, but the identifier which follows is enclosed in single quotes, e.g. <<<'EOT'. All the rules for heredoc identifiers also apply to nowdoc identifiers, especially those regarding the appearance of the closing identifier.
http://www.php.net/manual/en/language.types.string.php#language.types.string.syntax.nowdoc
$str = <<<'EOD'
Example of string
spanning multiple lines
using nowdoc syntax.
EOD;
If you want to use literal single or double quotes within single or double quoted strings, you have to escape them:
$str = '\''; // single quote
$str = "\""; // double quote
As Herbert noted, you don't have to escape single quotes within a double quoted strings and you don't have to escape double quotes within a single quoted string.
If you have to add quotes on a large scale, use the addslashes() function:
$str = "Is your name O'reilly?";
echo addslashes($str); // Is your name O\'reilly?
"O'reilly"
or 'She said, "Me too"'
–
Juta addslashes
is almost always wrong. The only valid use case is when you want to generate PHP code dynamically, which is something you should not do either. –
Ahola In fact in the PHP older than 8.0, you can really write the string literal without any quotes(so called bareword
) when there's no other global constant defined with the same name, since the bareword
will be recognized as a constant, then fall back to string literal if any constant with that name is not defined.
Example: https://3v4l.org/cT1ie
<?php
var_dump(Y);
var_dump(date(Y));
Fatal error: Uncaught Error: Undefined constant "Y" in /in/cT1ie:3
Stack trace:
#0 {main}
thrown in /in/cT1ie on line 3
Process exited with code 255.
Warning: Use of undefined constant Y - assumed 'Y' (this will throw an Error in a future version of PHP) in /in/cT1ie on line 3
string(1) "Y"
Warning: Use of undefined constant Y - assumed 'Y' (this will throw an Error in a future version of PHP) in /in/cT1ie on line 4
string(4) "2023"
Notice: Use of undefined constant Y - assumed 'Y' in /in/cT1ie on line 3
string(1) "Y"
Notice: Use of undefined constant Y - assumed 'Y' in /in/cT1ie on line 4
string(4) "2023"
From https://wiki.php.net/rfc/deprecate-bareword-strings:
When PHP encounters an unquoted token such as FROB_ACTIVE, it tries to resolve it as a built-in or user-defined constant, but if no such constant exists, it treats it as equivalent to the quoted string 'FROB_ACTIVE', and issues an E_NOTICE message. This behaviour has been around since very early versions of PHP, but is inconsistent with the rest of the language, and can lead to serious bugs. This RFC proposes three things: to raise the level of the message to E_WARNING; to officially deprecate the fallback; and to remove it in PHP 8.0.
and its discussion: https://externals.io/message/98025
© 2022 - 2025 — McMap. All rights reserved.
"\""
. – Immuno"
. – Immuno