$zero = "0"; $za = array("00"); if(in_array($zero, $za, true)){ echo 'in'; }else{ echo 'not in'; }
这段代码应该输出什么?答案是in,而不是not in。
然后测试一下这个:
$zero = "0"; $za = array("00"); if("0" == "00"){ echo '0 == 00'; }
返回'0'=='00'。
所以以后要注意:对于字符串不是说in,就表示那个字符在array里面。
2. strtolower()函数
我在这里谈过: http://www.iteye.com/topic/297460,我的解决方式是:
urldecode(strtolower(urlendoce($str)));
3. trim()
如果面对的是英文字符,那么trim()应该就满足了,但是对于中文字符,就应该重写以trim掉全角的空格:
function cntrim($value){ return trim(ereg_replace("^( )*|( )*$","", $value)); }
4. empty():
这个就有点像上面那个in_array()了,如果你要判断一个textarea里面是否有值,不能光使用empty,因为'0'字符串也会返回empty(但奇怪的是'00'就不会返回empty),重写以应对这种情况:
function non_szero_empty($value){ return empty($value) && $value != '0'; }
5. htmlentities():
与strtolower()类似,htmlentities也会出现一些转义gbk字符的问题,以致出现乱码。索性这样替换:
function _myhtmlentities($value){ //$value = preg_replace('/&((#(\d{3,5}|x[a-fA-F0-9]{4})|[a-zA-Z][a-z0-9]{2,5});)/', '&\\1', str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $value)); $value = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $value); return $value; }
不过现在还在疑惑为什么htmlentities会出现乱码,这样改为什么又可行。计划有时间看源代码一探究竟。