PHP的三元运算符通常在简洁与清晰度之间起关键作用。简要回顾:PHP三元运算符使您可以编写单行比较,从而替换如下代码:
<?phpif (isset($value)) {
$output = $value;} else {
$output = 'No value set.';}有了这个:
<?php$output = isset($value) ? $value : 'No value set.';
第二个代码示例显然更简单,并且在许多情况下(尽管当然不是全部),它仍然保留了足够的清晰度以成为有价值的工具。关于三元运算符是否以牺牲简洁为代价而牺牲了清晰度,存在很多争论。我们只说它是一种工具,并且像其他任何工具一样,它可以被很好地使用或不好使用。
常规三元运算符的语法为(expression) ? value if truthy : value if falsy。表达式也可以只是一个变量,它将测试该变量是真还是假:
<?php$output = $value ? $value : 'No value set.';
问题是,上面的示例既常见又令人讨厌,重复出现:不得不写$value两次这样的感觉简直是错。
好吧,我今天发现,PHP 5.3为此三元运算符的使用引入了偶数语法。您可以在docs上了解更多信息,但这是我们可以使以上示例更加简洁的方法:
<?php$output = $value ?: 'No value set.';
如果这看起来很熟悉,那是因为:这正是PHP缩短其他运算符的方式,例如缩短了它:
<?php$value = $value . $other_value;
对此:
<?php$value .= $other_value;
<?php //高先生简单验证码. //随机数 //为什么循环0-15的数字 //因为要实现最简单的字母和数字混搭 //16进制0-9 a-f //dechex 十进制转换为16进制 //创建一个四位的验证码. //$nmsg.  ...
应用场景:PHP模拟购买,商品数量大于0才能购买常见代码:<?php //连接数据库 $con=mysqli_connect("localhost","ihuohuo","927464cy","ihuohuo");...
md5/sha1+salt方式是目前各大cms常用的加密方式,虽然salt安全,但是各大md5网站也在研究这个方向,那么我们应该选择password_hash动态hash来助力,一种密码有多种hash结果.看代码模拟登陆.<?php //01.注册 $user ='zhang...
逛公众号文章看到文章"php实现事件监听与触发的方法,你用过吗?",我就好奇了,php又不是asp.net的webform,哪里来的服务端事件监听。于是学习了一波。先看下监听类:class Event { /** &nbs...
(1).config.php 配置文件<?php /** * RabbitMQ_Config */ $config = [ 'host' => ...
最近在公司开发一个新的项目假设项目域名是a.com,需要接入b.com的单点登陆系统。(1).首先我们会在a.com的登陆页面用iframe引入b.com来显示登陆界面,实际上登陆验证操作都是在b.com上面(2).当b.com验证通过,会在前端ajax请求a.com的回调地址,这个回调地址目的就是...