背景
在项目中很多人喜欢在配置文件使用数组来配置各个配置项,如等级的配置level.config.php:
<?php $g_levelConfig = array( '1'=>'新手', '2'=>'进阶', );
function getNameByLeval($level){ $level = intval($level); require_once CONFIG_PATH.'level.config.php'; if(!isset($g_levelConfig[$level])){ return false; }else{ return $g_levelConfig[$level]; } }
问题
那么这样会有什么问题呢?先看如下代码的输出,level.config.php即是上文提到的配置文件
<?php function getNameByLeval($level){ $level = intval($level); require_once 'level.config.php'; if(!isset($g_levelConfig[$level])){ return false; }else{ return $g_levelConfig[$level]; } } var_dump(getNameByLeval(1)); var_dump(getNameByLeval(2));
输出是:
string(6) "新手" bool(false)
很多人觉得很奇怪,为什么第二次输出的是false,其实很简单:
require_once只包含一次文件,如果该文件已经被包含了,则不会再次包含。
1.第一次执行getNameByLeval(1)时因为之前没包含level.config.php配置文件,所以本次会包含level.config.php文件并编译,所有函数里有$g_levelConfig变量;
2.当第二次执行getNameByLeval(1)时,因为之前包含过level.config.php配置文件,本次不再包含,所以就没有$g_levelConfig变量,自然返回false;
解决办法
1.在全局作用于包含,在函数中引用
<?php require_once 'level.config.php';//新增代码 function getNameByLeval($level){ global $g_levelConfig;//新增代码 $level = intval($level); if(!isset($g_levelConfig[$level])){ return false; }else{ return $g_levelConfig[$level]; } } var_dump(getNameByLeval(1)); var_dump(getNameByLeval(2));
2.在函数中包含、应用
<?php function getNameByLeval($level){ $level = intval($level); global $g_levelConfig;//新增代码 require_once 'level.config.php'; if(!isset($g_levelConfig[$level])){ return false; }else{ return $g_levelConfig[$level]; } } var_dump(getNameByLeval(1)); var_dump(getNameByLeval(2));
3.配置文件使用静态class
<?php class levelConfig{ public static $level = array( '1'=>'新手', '2'=>'进阶', ); }
使用的时候
function getNameByLeval($level){ $level = intval($level); require_once 'level.config.php'; if(!isset(levelConfig::$level[$level])){ return false; }else{ return levelConfig::$level[$level]; } }
我个人非常推崇这个方式来定义配置文件,用起来优雅而且不容易覆盖变量。
本文向大家介绍JavaScript定义变量和变量优先级问题探讨,包括了JavaScript定义变量和变量优先级问题探讨的使用技巧和注意事项,需要的朋友参考一下 看下面的代码: 回答以下问题: 会报错吗?会弹出几次? 第2个alert是true还是false? 第3个alert弹出什么? 为什么? 思考下,然后测试下,如果你回答正确,那么后面的文章就不用看了。 -------------------
形而上者谓之道,形而下者谓之器。 对于 Document/View 而言,很少有人能够先道而后器。 完全由AppWziard代劳做出的Scribble step0,应用程序的整个架构(空壳)都已经构造起来了,但是Document和View还空着好几个最重要的函数(都是虚函数)等着你设计其实体。这就像一部汽车外面的车体以及内部的油路电路都装配好了,但还等着最重要的发动机(引擎)植入,才能够产生动力,
本文向大家介绍探讨Ajax中的一些小问题,包括了探讨Ajax中的一些小问题的使用技巧和注意事项,需要的朋友参考一下 1.ajax跨域传递值是所需要的回传的类型为jsonp dataType 类型:String 预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个
本文向大家介绍JS函数的定义与调用方法推荐,包括了JS函数的定义与调用方法推荐的使用技巧和注意事项,需要的朋友参考一下 JS函数调用的四种方法:方法调用模式,函数调用模式,构造器调用模式,apply,call调用模式 1. 方法调用模式: 先定义一个对象,然后在对象的属性中定义方法,通过myobject.property来执行方法,this即指当前的myobject对象。 2. 函数调用模式 定义
本文向大家介绍探讨Java中函数是值传递还是引用传递问题,包括了探讨Java中函数是值传递还是引用传递问题的使用技巧和注意事项,需要的朋友参考一下 相信有些同学跟我一样,曾经对这个问题很疑惑。在网上也看了一些别人说的观点,评论不一。有说有值传递和引用传递两种,也有说只有值传递的,这里只说下个人见解 先给大家介绍下概念 值传递:(形式参数类型是基本数据类型):方法调用时,实际参数把它的值传递给对应的
本文向大家介绍Thinkphp中Create方法深入探究,包括了Thinkphp中Create方法深入探究的使用技巧和注意事项,需要的朋友参考一下 由于工作原因在thinkPHP的create()方法上遇到了问题,所以跟踪了create(),从而进一步探究了create()方法。 原来create()方法原来有两个参数,第一个参数就是众所周知的数据参数,第二个是隐藏的$type参数,那么这个参数用