ThinkPHP3.2框架自定义配置和加载用法示例


Posted in PHP onJune 14, 2018

本文实例讲述了ThinkPHP3.2框架自定义配置和加载用法。分享给大家供大家参考,具体如下:

有时候我们会有一些规则定义每个数字对应的实际内容,比如说在下拉菜单的时候:

<select name="reasonAndType" id="">
  <option value="1">查询物流</option>
  <option value="2">办理退货</option>
  <option value="3">咨询退货</option>
  <option value="4">咨询佣金</option>
  <option value="5">咨询规则</option>
  <option value="0">其他</option>
</select>

ThinkPHP3.2框架自定义配置和加载用法示例←实际效果

ThinkPHP3.2框架自定义配置和加载用法示例←数据库存的效果

ThinkPHP3.2框架自定义配置和加载用法示例←显示的时候。

这个例子里,实际显示的是汉字,实际的value值是数字,等我们向数据库存的时候也是存数字,等我们从数据库获取的时候也是取数字,显示的时候也是显示汉字;

所以我们需要一个类似字典的东西,它定义了那个数字对应的汉字是什么,定义的实际意义是什么;

用数据库能够实现这个效果,但我们不用,因为对数据库的操作开销太大;

如果是普通的PHP环境,我们可以把规则单独存到一个文件里,内容是一个数组:

type.PHP

$type = array(
'1' => '查询物流',
'2' => '办理退货',
'3' => '咨询退货',
'4' => '咨询佣金',
'5' => '咨询规则',
'0' => '其他'
);

就像上面代码那样,定义好之后,存成一个文件,当我们需要调用这个这个规则的时候,就include或者require,然后直接用$type这个变量去找就行了,比如:

require_once('type.php');
echo $type[1]; //输出'查询物流'
foreach($type as $k => $v){ //直接打印出最上面的下拉菜单代码,
echo "<option value = '{$k}' >{$v}</option>";
}

如果在ThinkPHP,要是想引入文件,只能用绝对路径,在include和require用__APP__或者__ROOT__快捷入口是不行的,U()造链函数我没试,应该是可以实现的。

还有一种实现方式,也是我在这里推荐的,就是直接把这套规则定义为这个网站的配置文件,当我们用的时候,用C()加载配置函数把这个数组加载出来赋给一个变量就好了。

上代码了:

把你定义的规则放到conf下,这是私有配置文件,只有Home这个入口的才生效,也可以放到公共配置文件下,细节可以去查手册。

return array(
'REASON_AND_TYPE' => array(
'1' => '查询物流',
'2' => '办理退货',
'3' => '咨询退货',
'4' => '咨询佣金',
'5' => '咨询规则',
'0' => '其他'
)
);

注意加上return;

注意,格式,return一个数组,键名是大写的(为了好看),键值是你要定义的东西,在这里我们定义的是一个数组。

修改config.php文件

<?php
return array(
//'配置项'=>'配置值'
'DB_TYPE' => 'mysqli', // 数据库类型
'DB_HOST' => 'localhost', // 服务器地址
'DB_NAME' => 'kefu', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => 'root', // 密码
'DB_PORT' => '', // 端口
'DB_PREFIX' => '', // 数据库表前缀
'LOAD_EXT_CONFIG' => 'reasonAndType', //这是我们自己添加的,LOAD_EXT_CONFIG键名固定,键值是你的php文件的文件名,那个数组名字在这里就不用管了
);

这就算配置好了。

下面讲调用这套规则:

$reasonAndTypeX = C('REASON_AND_TYPE');
//直接用数组名字就可以了,C()函数能加载配置里的键名所代表的值,赋给变量

注意,C()函数的里面的值,是reasonAndType这个文件的值。

var_dump($reasonAndTypeX);

就会输入这个数组的内容

array(
'1' => '查询物流',
'2' => '办理退货',
'3' => '咨询退货',
'4' => '咨询佣金',
'5' => '咨询规则',
'0' => '其他'
);

这样就完成了自定义配置文件的设置和加载。

如果‘REASON_AND_TYPE'没有配置,则会返回一个null值;

当然,你也可以设置默认值,代码如下:

// 如果REASON_AND_TYPE尚未设置的话,则返回default_config字符串
C('my_config',null,'default_config');

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

PHP 相关文章推荐
用PHP和ACCESS写聊天室(六)
Oct 09 PHP
MySQL GBK→UTF-8编码转换
May 24 PHP
PHP读取PDF内容配合Xpdf的使用
Nov 24 PHP
php笔记之:文章中图片处理的使用
Apr 26 PHP
Codeigniter+PHPExcel实现导出数据到Excel文件
Jun 12 PHP
php调用shell的方法
Nov 05 PHP
php为字符串前后添加指定数量字符的方法
May 04 PHP
php+mysql实现简单登录注册修改密码网页
Nov 30 PHP
Yii2实现UploadedFile上传文件示例
Feb 15 PHP
PHP面向对象之事务脚本模式(详解)
Jun 07 PHP
统计PHP目录中的文件数方法
Mar 05 PHP
laravel5.1 ajax post 传值_token示例
Oct 24 PHP
thinkPHP框架实现多表查询的方法
Jun 14 #PHP
php微信开发之关注事件
Jun 14 #PHP
thinkPHP框架动态配置用法实例分析
Jun 14 #PHP
php微信开发之谷歌测距
Jun 14 #PHP
php微信开发之图片回复功能
Jun 14 #PHP
php微信开发之音乐回复功能
Jun 14 #PHP
php微信开发之关键词回复功能
Jun 13 #PHP
You might like
php压缩HTML函数轻松实现压缩html/js/Css及注意事项
2013/01/27 PHP
ThinkPHP框架表单验证操作方法
2017/07/19 PHP
详解php协程知识点
2018/09/21 PHP
JS实多级联动下拉菜单类,简单实现省市区联动菜单!
2007/05/03 Javascript
关于取不到由location.href提交而来的上级页面地址的解决办法
2009/07/30 Javascript
javscript对象原型的一些看法
2010/09/19 Javascript
JavaScript面对国际化编程时的一些建议
2015/06/24 Javascript
JavaScript使用RegExp进行正则匹配的方法
2015/07/11 Javascript
详解JavaScript对象类型
2016/06/16 Javascript
把普通对象转换成json格式的对象的简单实例
2016/07/04 Javascript
全面了解addEventListener和on的区别
2016/07/14 Javascript
详解AngularJs HTTP响应拦截器实现登陆、权限校验
2017/04/11 Javascript
详解angularjs 关于ui-router分层使用
2017/06/12 Javascript
Angular实现表单验证功能
2017/11/13 Javascript
node.js部署之启动后台运行forever的方法
2018/05/23 Javascript
JS数组去重常用方法实例小结【4种方法】
2018/05/28 Javascript
JS实现前端页面的搜索功能
2018/06/12 Javascript
微信小程序实现签到弹窗动画
2020/09/21 Javascript
python使用htmllib分析网页内容的方法
2015/05/08 Python
python OpenCV学习笔记直方图反向投影的实现
2018/02/07 Python
Django1.9 加载通过ImageField上传的图片方法
2018/05/25 Python
Python读写zip压缩文件的方法
2018/08/29 Python
实例详解Python模块decimal
2019/06/26 Python
python射线法判断一个点在图形区域内外
2019/06/28 Python
django中嵌套的try-except实例
2020/05/21 Python
Python文件操作及内置函数flush原理解析
2020/10/13 Python
HTML5网页音乐播放器的示例代码
2017/11/09 HTML / CSS
只要五步 就可以用HTML5/CSS3快速制作便签贴特效(图)
2012/06/04 HTML / CSS
科室工作个人总结的自我评价
2013/10/29 职场文书
办理居住证介绍信
2014/01/15 职场文书
给儿子的表扬信
2014/01/15 职场文书
仓库文员岗位职责
2014/04/06 职场文书
电话客服专员岗位职责
2014/06/28 职场文书
运动会加油稿100字
2014/09/19 职场文书
医院护士工作检讨书
2014/10/26 职场文书
彻底卸载VMware虚拟机的超详细步骤记录
2022/07/15 Servers