广告投放

PbootCMS二开教程(一)新增左侧菜单与页面

目录

    第一步:后台进入【菜单管理】

    路径(http://您的域名/admin.php?p=/Menu/index)

    进入后选择【菜单新增】

    名词解释:

    【父菜单】如果是顶级菜单,无需切换,如果需要放到哪个分类下,选择对应分类即可

    【菜单名称】设置菜单在后台显示的名称

    【URL】即后台菜单的路径

    【快捷图标】可以到Font Awesome 中文网选择自己喜欢的图标(http://www.fontawesome.com.cn/icons/area-chart/)


    相关内容编辑好后,点击【立即提交】就添加成功了

    添加成功后需要【退出登录】,然后重新登录就可以看到新增的菜单项了,完成这一步仅仅只是开始,接下来我们需要到对应文件夹下新增几个文件,让页面成功的显示出来

    PbootCMS二开教程(一)新增左侧菜单与页面

    如果需要修改菜单信息,可以点击【修改】进入下方页面进行调整

    PbootCMS二开教程(一)新增左侧菜单与页面

    第二步:尝试在新页面获取日志信息

    PbootCMS主要采用的是MVC模式,所以我们需要对应的增加三个文件

    (MVC开始是存在于桌面程序中的,M是指业务模型,V是指用户界面,C则是控制器,使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。)

    1、在路径/apps/admin/model/system/下新增Model模型文件,文件名称为 TongjiModel.php

    为了方便测试,我们复制/apps/admin/model/system/SyslogModel.php 文件中的所有文件到新建好的控制器文件中

    把:class SyslogModel extends Model  修改为:class TongjiModel extends Model

    <?php
    /**
     * @copyright (C)2016-2099 Hnaoyun Inc.
     * @author XingMeng
     * @email hnxsh@foxmail.com
     * @date 2017年3月29日
     *  日志模型类
     */
    namespace appdminmodelsystem;
    
    use coreasicModel;
    
    class TongjiModel extends Model
    {
    
        // 获取日志列表
        public function getList()
        {
            return parent::table('ay_syslog')->order('id DESC')
                ->page()
                ->select();
        }
    
        // 删除全部
        public function clearLog()
        {
            return parent::table('ay_syslog')->delete();
        }
    }

    2、在路径/apps/admin/controller/system/下新增Controller控制器文件,文件名称为 TongjiController.php

    为了方便测试,我们复制/apps/admin/controller/system/SyslogController.php 文件中的所有文件到新建好的控制器文件中,本文件主要需要修改四处

    反斜杠被编辑器转化了,请对照实际内容进行调整,主要修改名称

    把:use appdminmodelsystemSyslogModel; 修改为  use appdminmodelsystemTongjiModel;

    把:class SyslogController extends Controller  修改为  class TongjiController extends Controller

    把:$this->model = new SyslogModel();  修改为  $this->model = new TongjiModel();

    把:$this->display('system/syslog.html');  修改为  $this->display('system/tongji.html');

    <?php
    /**
     * @copyright (C)2016-2099 Hnaoyun Inc.
     * @author XingMeng
     * @email hnxsh@foxmail.com
     * @date 2017年3月29日
     *  系统日志控制器
     */
    namespace appdmincontrollersystem;
    
    use coreasicController;
    use appdminmodelsystemTongjiModel;
    
    class TongjiController extends Controller
    {
    
        private $model;
    
        public function __construct()
        {
            $this->model = new TongjiModel();
        }
    
        // 日志列表
        public function index()
        {
            $this->assign('syslogs', $this->model->getList());
            $this->display('system/tongji.html');
        }
    
        // 清理日志
        public function clear()
        {
            if ($this->model->clearLog()) {
                alert_location('清空成功!', url('/admin/Tongji/index'));
            } else {
                alert_location('清空失败!', url('/admin/Tongji/index'));
            }
        }
    }

    3、在路径/apps/admin/view/default/system/下新增View页面文件,文件名称为 tongji.html

    我们复制/apps/admin/view/default/system/syslog.html 里面的文件到新建好的文件中

    以上就完成了MVC创建基础流程,当然为了更好的适配环境,我们需要将这个新建的文件加入到后台路由中,以防止部分空间因环境问题而无法访问建好的页面

    {include file='common/head.html'}
    
    <div class="layui-body">
    	<div class="layui-tab layui-tab-brief" lay-filter="tab">
    	  <ul class="layui-tab-title">
    	    <li class="layui-this" lay-id="t1">系统日志</li>
    	  </ul>
    	  <div class="layui-tab-content">
    	  	   <div class="layui-tab-item layui-show">
    		  	   	<table class="layui-table">
    	            	<thead>
    	                    <tr>
    	                        <th>序号</th>
    	                        <th>事件内容</th>
    	                        <th>用户IP</th>
    	                        <th>操作系统</th>
    	                        <th>浏览器</th>
    	                        <th>用户名</th>
    	                        <th>时间</th>
    	                    </tr>
    	                </thead>
    	                <tbody>
    	                    {foreach $syslogs(key,value,num)}
    	                    <tr>
    	                        <td>[num]</td>
    	                        <td>[value->event]</td>
    	                        <td>{fun=long2ip($value->user_ip)}</td>
    	                        <td>[value->user_os]</td>
    	                        <td>[value->user_bs]</td>
    	                        <td>[value->create_user]</td>
    	                        <td>[value->create_time]</td>
    	                    </tr>
    	                    {/foreach}
    	                </tbody>
    	            </table>
    	            {if(session('ucode')==10001 && [$syslogs])}
    	            	<a href="{url./admin/Syslog/clear}" class="layui-btn layui-btn-sm"  onclick='return confirm("您确定要清空么?")'>清空日志</a>
    	            {/if}
    	            <div class="page">{$pagebar}</div>
    	  	   </div>
    	  </div>
    	</div>	
    </div>
    
    {include file='common/foot.html'}

    4、找到/apps/common/路径下的 route.php 文件,新增后台路由规则

    参照其他页面的路由规则,添加好我们已经建好的新页面规则,然后保存,后台新增页面流程就基本完成了

    我们可以进入后台,找到新增的菜单位置,点击菜单选项,就可以进入到新增的对应菜单页面了

    PbootCMS二开教程(一)新增左侧菜单与页面

    最终效果如图所示,当然,我是已经对接了数据库的统计表,所以显示的是统计表的信息

    PbootCMS二开教程(一)新增左侧菜单与页面


    声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

    给TA打赏
    共{{data.count}}人
    人已打赏
    广告位招租919838898
    0 条回复 A文章作者 M管理员
      暂无讨论,说说你的看法吧
    个人中心
    购物车
    优惠劵
    今日签到
    有新私信 私信列表
    搜索