FastAdmin

注意食用姿势,建议先通读官方文档一次,在看

根据环境及配置的不同,仅作参考

修改mysql表注释
ALTER TABLE student COMMENT '学生表';

系统配置->邮件配置(测试发送成功)

注意在邮箱中开启

  POP3/SMTP服务

  IMAP/SMTP服务

  需PHP5.6版本,7以上版本不支持

SMTP用户名  ->  邮箱地址

SMTP密码   ->  在邮箱账户设置中生成的授权码

发件人邮箱     ->  属于当前邮箱的账号都可作为发件人邮箱

fastadmin设置首页直接跳转后台登录
$this->redirect('admin/index/login');

去除首页安全提示(隐藏admin登录入口)

在application的config.php中修改 deny_module_list 添加 admin 如下:

'deny_module_list'       => ['common','admin']

修改public中的admin.php文件名为 xxx.php(可以改为任意符合PHP命名规则的名称)

访问:www.yoursite.com/xxx.php 即可

如已配置前台自动跳转登录需将跳转方法改为:

$this->redirect('xxx.php/index/login');

{:xxx}

引用PHP函数

{:build_toolbar('refresh,add,delete')}

在application/common.php中,用于生成HTML页面

$this->assignconfig('demo', '传参到JS测试');

将数据透传到JS中,可直接在JS中使用

设置页面数据必填

在input标签中添加
data-rule="required"

requirejs

页面中的js统一由requorejs管理

视图、控制器、JS一一对应,

如:

application/admin/controller  /user/index  控制器对应

application/admin/view  /user/index  视图对应

public/assets/js/backend  /user/index  JS

var Orderdata = {
column: {:json_encode(array_keys($paylist))},
paydata: {:json_encode(array_values($paylist))},
createdata: {:json_encode(array_values($createlist))},
};
将页面中的数据放入对象,可在JS中使用

admin/view/user/user/index.html

{:build_toolbar('refresh,edit,del')}
用于控制页面图标显示
data-operate-edit="{:$auth->check('user/user/edit')}" 
控制表格操作显示
对应JS中
Table.api.init
初始化路由参数,删除后不可提交
extend-扩展类库
vendor-第三方类库
extra-扩展配置目录

框架只能加载首页时(域名后加上index.php也可以访问其他页面),在服务器添加伪静态,内容同下

去除PHP域名解析时的index.php
在文件入口处添加.htaccess文件
<IfModule mod_rewrite.c>
Options +FollowSymlinks -Multiviews
RewriteEngine On

RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php?/$1 [QSA,PT,L]
</IfModule>

FastAdmin

开关中提示“未更新任何行”在相应控制器中添加

protected $multiFields = 'status,switch';

或在基类中添加switch

/**
* Multi方法可批量修改的字段
*/
protected $multiFields = 'status,switch';

依然无用则在相应控制器中覆盖

/**
* 批量操作
* @param string $ids
*/
public function multi($ids = "")
{
$params = $this->request->request('params');
parse_str($params, $paramsArr);
if (isset($paramsArr)) {
$field = \app\admin\model\Test3::get($ids);
$field->save($paramsArr);
$this->success('操作成功');
}
return parent::multi($ids);
}
 

_id

两种方式,一种系统配置,一种自己添加

一、系统配置(不需要修改页面代码,只添加数据即可)

  常规管理->系统配置->字典配置中添加分类类型

    类型与数据库表名对应(不要前缀)(键相同会覆盖值)

  在分类管理中添加分类

    类型与字典配置中的值一致

此时去对应的视图中即可获取到数据

二、手动设置读取的字段

data-source="category/selectpage"     对应的控制器
data-params='{"custom[type]":"test"}'  展示的值
name="row[category_ids]"          当前表单提交的对应字段

_id使用
需确认相应input属性data-source所对应的控制器,默认获取name字段的,可用data-field设置需要读取的字段信息

data-field="id" data-source="test/index"

全句如下:

<input id="c-test_id" data-rule="required" data-source="test/index" class="form-control selectpage" name="row[test_id]" type="text" value="">

外键关联查询

->with(['cart'=>function($query){
$query->withField('');
$query->where();
},
])

高级模式

public function index()
{
$this->relationSearch = true;
$this->searchFields = "id";
if ($this->request->isAjax()) {
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
$total = $this->model
->with("cart")
->with(['cart'=>function($query){
$query->withField('');
$query->where();
},
])
->where($where)
->order($sort, $order)
->count();
$list = $this->model
->with("cart")
->where($where)
->order($sort, $order)
->limit($offset, $limit)
->select();
$result = array("total" => $total, "rows" => $list);
return json($result);
}
return $this->view->fetch();
}

enum和set类型生成对应的字段注释

创建字段后填写相应值
在字段注释中添加相应值的选项,如下
单选下拉:1=单选1,2=单选2,3=单选3,4=单选4,5=单选5

后台/admin

前台/controller
/view
模板基类/default/common/layout
首页/default/index
右侧推荐/default/common/sidebar
表单/default/diyform
单页/default/page
专题/default/special

首页index </aside>标签之上 删除的右侧栏
{include file="common/sidebar" /}

fastadmin框架信息
{$site.name}
如果是数组类型调用如下:
<?php print_r($site); ?>

CMS配置信息
{$config.sitename}
如果是数组类型调用如下:
<?php print_r($config); ?>

控制器——application\admin\controller\student\Student.php

模型层——application\admin\model\Srudent.php

视图层——application\admin\view\student\student

验证规则——application\admin\validate\Student.php

语言包——application\admin\lang\zh-cn\student\student.php

js文件——public\assets\js\backend\student\student.js

FastAdmin-T的更多相关文章

  1. Fastadmin安装以及各种问题解决

    FastAdmin是一款基于ThinkPHP5+Bootstrap的极速后台开发框架 https://www.fastadmin.net/ 参照官方文档安装,还是有坑的 首先注意:无需下载PHP.Th ...

  2. fastadmin模态框(弹出框)

    用法: 在html页面新建一个按钮用来触发事件 <a href="javascript:;" class="btn btn-success btn-add &quo ...

  3. 基于fastadmin快速搭建后台管理

    FastAdmin是一款基于ThinkPHP5+Bootstrap的极速后台开发框架:开发文档 下面对环境搭建简要概述,希望后来者能少走弯路: 1. 百度搜索最新版wampserver, 安装并启动 ...

  4. 了解fastadmin标准的控制器模块js的表格事件

    controller/A.php<-------------->public/assets/js/backend/a.js controller/b/A.php<---------- ...

  5. fastadmin默认的controller已实现的方法

    fastadmin控制器 <?php namespace app\admin\controller\peizi; use app\common\controller\Backend; /** * ...

  6. 一张图解析FastAdmin中的表格列表的功能

    大图: 1.默认生成的CRUD是没有菜单名称和描述显示的,如果需要显示则可以在后台修改,权限管理->菜单规则,给对应菜单的添加上备注信息后即可显示,支持HTML 2.TAB过滤选项卡 在一键生成 ...

  7. fastAdmin进阶

    基本知识流程一栏链接 bootstrapTable fastadmin系统配置(符内置规则): fastadmin默认的controller已实现的方法 一张图解析fastadmin的表格: fast ...

  8. FastAdmin 基本知识流程一栏

      fastadmin进阶 安装:出现登陆页无法显示:可能是php的gd2扩展未开启 FastAdmin 在 Nginx 中的配置 用的是AdminLTE后台模板require.js.less.Bow ...

  9. FastAdmin 在 Nginx 中的配置

    FastAdmin 使用的是 ThinkPHP 5 框架. 在 Apache 下很简单,但是在 nginx 下就需要自行配置一下了. 在网上找了很多,都没有找到很好的. 刚刚在 QQ 里群里找到一个, ...

  10. FastAdmin 的上传代码在哪里?

    FastAdmin 的上传代码在哪里? FastAdmin 默认是通过 Ajax 上传到本地. 使用 admin/ajax/upload 方式返回 url. 代码文件地址在 application\a ...

随机推荐

  1. mysql random 字母大小写和数字

    delimiter $$drop function if exists rand_string;create function rand_string(n int) returns varchar(2 ...

  2. WPF界面开发必备技能!TreeListView - 如何快速更新多个项目属性

    DevExpress广泛应用于ECM企业内容管理. 成本管控.进程监督.生产调度,在企业/政务信息化管理中占据一席重要之地.通过DevExpress WPF Controls,您能创建有着强大互动功能 ...

  3. ELementD对象

    在 HTML DOM (文档对象模型)中,每个部分都是节点: 文档本身是文档节点 所有 HTML 元素是元素节点 所有 HTML 属性是属性节点 HTML 元素内的文本是文本节点 注释是注释节点 El ...

  4. 决策树--CART树详解

    1.CART简介 CART是一棵二叉树,每一次分裂会产生两个子节点.CART树分为分类树和回归树. 分类树主要针对目标标量为分类变量,比如预测一个动物是否是哺乳动物. 回归树针对目标变量为连续值的情况 ...

  5. Acwing-285-没有上司的舞会(树型DP)

    链接: https://www.acwing.com/problem/content/287/ 题意: Ural大学有N名职员,编号为1~N. 他们的关系就像一棵以校长为根的树,父节点就是子节点的直接 ...

  6. django之ajax结合sweetalert使用,分页器和bulk_create批量插入 07

    目录 sweetalert插件 bulk_create 批量插入数据 分页器 简易版本的分页器的推导 自定义分页器的使用(组件) sweetalert插件 有这么一个需求: ​ 当用户进行一个删除数据 ...

  7. poj 3050 Hopscotch DFS+暴力搜索+set容器

    Hopscotch Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2774 Accepted: 1940 Description ...

  8. codeforces340C

    Tourist Problem CodeForces - 340C Iahub is a big fan of tourists. He wants to become a tourist himse ...

  9. 本地Git连接远程Gitlab

    本地端安装https://www.cnblogs.com/wei9593/p/11698204.html 1.打开本地git bash,使用如下命令生成ssh公钥和私钥 ssh-keygen -t r ...

  10. TypeScript----接口和泛型

    接口 TypeScript的核心原则之一是对值所具有的结构进行类型检查.它有时被称做“鸭式辨型法”或“结构性子类型化”.在TypeScript里,接口的作用就是为这些类型命名和为你的代码或第三方代码定 ...