thinkphp的c方法使用示例
1.c方法的作用
a. 加载设置用户的配置,保存在一个c函数内的静态变量$_config 中
b. 读取用户的配置 (从$_congig 中读取)
2. 需求分析:
1.设置变量
1.二维数组
c(array('db_password'=>'root','db_username'=>'root'),'db');
c('db.user_name','xiaochen);
2.一维数组
c('user_name','小陈');
c(array('user_name'=>'chen','user_height'=>'170'));
2.读取变量
一维: c('user_name');
二维: c('db.db_password');
3.调试时,查看所有的配置信息
c();
3.存放方式及为什么要这样存储?
首先我们来看一个问题$arr=array('db'=>'mysql','db'=>'mysql','db'=>'mysql'); 从这个数组我们可以看到db都是指向了mysql,但是在却占用了三个存放空间,在项目的开发不是由一个人完成,每个人的书写习惯可能不一样,所以为了避免这种情况,统一的下标转为小写(当然大写也是可以的),由于配置文件在中的数组只有最多只有二维,把一维数组的下标小写就够了
4.实战中是怎么用的?
php由于对数组的操作非常便捷,所以配置文件一般是写在一个配置文件中,以数组的形式返回
一般格式为:
config.php<? return array('db'=>'mysql',......);
把变量写入到c中 : c(include 'config.php'); 写入后c('db') 就可以获取值了
5.笔者写的 (新增动态添加二维配置的功能)
c(array('name'=>'mysql','password'=>'root'),'db') 执行后array('db'=>array('name'=>'mysql','password'=>root))
代码示例:
function c($name=null,$value=null){
static $_config = array();
if(!is_null($name)){
if(is_string($name)){
if(is_null($value)){
if(!strpos($name,'.')){
$name = strtolower($name);
return isset($_config[$name]) ? $_config[$name] : null;
}else{
$name = explode('.',$name);
$name[0] = strtolower($name[0]);
return isset($_config[$name[0]][$name[1]]) ? $_config[$name[0]][$name[1]] : null;
}
}else{
if(!strpos($name,'.')){
$_config[strtolower($name)] = $value;
}else{
$name = explode('.',$name);
$_config[strtolower($name[0])][$name[1]] = $value;
}
return ;
}
}elseif(is_array($name)){
if(is_null($value))
$_config = array_merge($_config,$name);
else{
$_config[$value] = $name;
}
return ;
}
}else{
return empty($_config) ? null: $_config;
}
}
上一篇: JavaScript中使用Math.PI圆周率属性的方法
下一篇: [C6技巧]恢复已删除的流程
推荐阅读
-
JavaScript使用IEEE 标准进行二进制浮点运算产生莫名错误的解决方法_javascript技巧
-
vue mixins与extends的使用方法
-
jquery中get,post和ajax方法的使用小结_jquery
-
node.js中的fs.unlink方法使用说明_node.js
-
详解Python中expandtabs()方法的使用
-
thinkphp中连接oracle时封装方法无法用的解决办法
-
MySQL Like语句的使用方法_MySQL
-
在 PHP 和 Laravel 中使用 Traits的方法
-
实用的简单PHP分页集合包括使用方法
-
在Django的URLconf中使用命名组的方法