基于TP框架的fastadmin开发插件基本流程
本文为php中文网认证作者:“世界的背影”投稿,欢迎加入php中文网有偿投稿计划!
FastAdmin是一款基于ThinkPHP5+Bootstrap的极速后台开发框架。
以一个学校管理插件为例
PHPSTORM
phpstudy
nginx1.15.11
mysql8.0
php7.3.4
配置站点
我的域名设置为fast51admin.localhost.nyist.vip
安装fastadmin可以使用git克隆项目至本地或者下载安装包。
下载后解压到对应站点目录下,设置网站根目录至文件的public目录下(与tp一致)
解压后的文件
然后为网站设置对应的NGINX规则
如果成功则访问网站时可以看到,用户为admin,密码为123456
这是本次实例的规则
注:使用phpstudy时规则修改在网站对应的vhost文件中。
以学校管理实例为例
在你安装fastadmin成功后,会自动生成一个数据库fast51
而我们自己要创建的表也在此数据库中
这是fastadmin的一个强大功能,可以使用命令行一键生成对应数据表的控制器,模型,视图,验证器,语言包,JS等。
一键生成crud的命令
php think crud -t test
这里“-t”参数指定你要生成的数据表(可以不用写前缀名)
常用参数
-c, –controller[=CONTROLLER] 生成的控制器名,可选,默认根据表名进行自动解析
-m, –model[=MODEL] 生成的模型名,可选,默认根据表名进行自动解析
-i, –fields[=FIELDS] 生成的数据列表中可见的字段,默认是全部
-d, –delete[=DELETE] 删除模式,将删除之前使用CRUD命令生成的相关文件
fastadmin可通过命令控制台快速的一键生成后台的权限节点菜单规则,同时后台的管理菜单也会同步改变
一键生成menu的命令
php think menu -c test
这里“-c”参数指定控制器
生成后的样子
测试各个自动生成的功能是否正常,是否满足自身需求
FastAdmin可以通过命令行创建一个插件
一键生成addon的命令
php think addon -a mydemo -c create
这里“-a”参数指定插件的名称
执行该命令后会在addons目录中生成对应文件
其中的application对应的是tp自带的application文件夹
也就是前几步我们生成的文件所在的位置
将之前我们在crud中生成的文件按对应目录复制到application中
导出我们的所有数据表,在将其合并入install.sql中
需要在插件目录中对应的插件名.php中创建插件的后台管理菜单。
注:install.sql会在插件第一次安装时执行
命令行打包
//mydemo为你的插件目录名称
php think addon -a mydemo -c package
手动打包
进入你要打包的插件目录中,选中所有文件,压缩成zip压缩包
使用fastadmin可以极大加快开发速度,其中还有许多细节需查阅官方文档。
一个简单的部门案例详解(PHP代码实例)
本文为php中文网认证作者:“易达”投稿,欢迎加入php中文网有偿投稿计划!
案例:
要求:
其中必须要使用的知识点:
1. 类的定义
2. 类的实例化
3. 对象的引用赋值=&
4. 析构函数
5. 构造函数
这个案例要实现的效果其实算很简单,但是重点是,你的思路很清楚吗?你的思路是否具备一定的条理性,或者说做了许多项目,你有没有总结出一套你自己的系统性的思路方案呢?我的总结如下:
3个分析:
1、流程分析
2、具体的实现分析
3、 数据库分析
3个执行:
1.创建数据库,初始化数据库数据( 项目的启动数据 )
2.创建类,实现类
3.写流程
接下来我们一个一个的分析
1、流程分析
1、获取所有部门信息
2、获取单个部门信息
3、写一个对象引用赋值=&的测试
例如$jordon1=&$jordon
4、在所有逻辑最后写一句话:应用程序到此为止
5、执行了一个类的析构函数
2、具体的实现分析
1、第一步:识别对象(找名词)
根据上面的流程我们得出的对象只有一个:
1.部门
2、第二步:识别对象的属性( 数据名词+结合现实世界去分析+结合具体的场景 )
1.部门:属性有:id,名称
3、第三步:识别对象的方法( 动词+结合现实世界去分析+结合具体的场景 )
1.部门 方法有
1.获取所有部门信息
2.获取单个部门信息
因为所有的数据都要保存到数据库,所有的数据都要从数据库获取,所以接下来
数据库分析:
表:(有多少个对象 至少就有多少个表)
1.部门 字段 = 对象的属性
分析完成后,我们接下来做具体的操作
1、创建数据库,初始化数据库数据( 项目的启动数据 )
创建数据库,名字我们就叫做depart
为数据库创建表,表明就做叫部门表
分析是否有初始化数据,(我们可以称之为项目的启动数据,没有这些数据,项目无法启动,)然后将这些初始化数据写入数据库
综上分析,初始化数据就是3个部门
所以接下来我们初始化数据库
2.创建类,实现类
创建部门类:
为了方便管理,我们把所有的类放到model文件夹中,然后这个类文件我们就叫做Depart.class.php,然后我们把上面分析得出来的类的属性和方法,写入部门类中
model/Depart.class.php
<?php
//部门类
class Depart{
//定义属性 id,名称
public $id = \”\”;
public $name = \”\”;
public $conn = \”\”;//数据库连接
public $tableName = \”depart\”;//表名
//构造函数
public function __construct( $id,$name ){
//初始化属性
$this->id = $id;
$this->name = $name;
//初始化行为 初始化方法
$this->initConn();
}
//析构函数 销毁数据库连接
public function __destruct(){
//销毁连接
if( $this->conn ){
mysqli_close( $this->conn );
echo \”销毁了连接<br/>\”;
}
}
//定义方法
//创建公共的方法 获取数据库连接
public function initConn(){
$config = Array(
\”hostname\”=>\”127.0.0.1\”,
\”database\”=>\”depart\”,
\”username\”=>\”root\”,
\”password\”=>\”root\”
);
$this->conn = mysqli_connect( $config[\’hostname\’],$config[\’username\’] ,$config[\’password\’],
$config[\’database\’]);
}
// 1.获取所有部门信息
public function getAll(){
//创建数据库连接
$conn = $this->conn;
//写sql
$sql = \” select * from \”.$this->tableName;
//执行sql
$result = mysqli_query( $conn,$sql );
//获取数据
// mysqli_fetch_all($result)//特点:不会包含字段名
$list = Array();
while( $row = mysqli_fetch_assoc( $result ) ){
$list[] = $row;
}
//返回数据
return $list;
}
// 2.获取单个部门信息
public function getOne( $id ){
//创建数据库连接
$conn = $this->conn;
//写sql
$sql = \” select * from \”.$this->tableName.\” where id= \”.$id;
//执行sql
$result = mysqli_query( $conn,$sql );
//获取数据
// mysqli_fetch_all($result)//特点:不会包含字段名
$list = Array();
while( $row = mysqli_fetch_assoc( $result ) ){
$list[] = $row;
}
//返回数据
return $list;
}
}
?>
3.写流程
接下来,我们根据流程分析的结果来写具体的流程,流程代码如下:
<?php
//引入类文件
require_once \”model/Depart.class.php\”;
//写流程
// 1.获取所有部门信息
//
$humanResourseDepartment = new Depart(2,\”行政部门\”);
//通过对象调用方法
$alllist = $humanResourseDepartment->getAll();
echo \”<b>所有部门信息为:</b><br/>\”;
print_r( $alllist );
echo \”<br/>\”;
// 2.获取单个部门信息 = 开发部门
$devDepartment = $humanResourseDepartment ->getOne( 1 );
echo \”<b>开发部门信息:</b> <br/>\”;
print_r( $devDepartment );
echo \”<br/>\”;
// 3.对象引用赋值=&的测试
// $jordon1=&$jordon
$humanResourseDepartment1 =& $humanResourseDepartment;
echo \”修改前:行政部门的名字为:\”.$humanResourseDepartment->name.\”<br/>\”;
//修改
$humanResourseDepartment1->name = \”人力部门\”;
echo \”修改后:行政部门的名字为:\”.$humanResourseDepartment->name.\”<br/>\”;
// 4.在所有逻辑最后写一句话:应用程序到此为止
echo \”<b>应用程序到此为止</b> <br/>\”;
// 5.执行了一个类的析构函数
?>
运行结果如下:
所有部门信息为:Array ( [0] => Array ( [id] => 1 [name] => 开发部门 ) [1] => Array ( [id] => 2 [name] => 行政部门 ) [2] => Array ( [id] => 3 [name] => 后勤部门 ) )开发部门信息:Array ( [0] => Array ( [id] => 1 [name] => 开发部门 ) )修改前:行政部门的名字为:行政部门修改后:行政部门的名字为:人力部门应用程序到此为止销毁了连接
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。