1. 新建存储菜单的配置文件 menus.php,并配置菜单

    <?php  if ( ! defined('BASEPATH')) exit('No direct script access allowed');
    /*菜单配置*/
    $config['menus'] = array();
    // 校园生活
    $config['menus']['life'] = array('name' => '学校生活',
    'submenu' => array(
    'news/official_news' => array('name' => '官网公告'),
    'life/game' => array('name' => '校园活动', 'link' => 'life/game'),
    'life/flea' => array('name' => '跳蚤专场', 'link' => 'life/flea'),
    'life/calendar' => array('name' => '跳蚤专场', 'link' => 'life/calendar'),
    'life/map' => array('name' => '校园地图', 'link' => 'life/map'),
    'life/scenery' => array('name' => '校园美景', 'link' => 'life/scenery'),
    'life/schoolcard_lose' => array('name' => '一卡通丢失', 'link' => 'life/schoolcard_lose'),
    'life/schoolcard_found' => array('name' => '一卡通招领', 'link' => 'life/schoolcard_found'),
    )
    );
    // 校园学习
    $config['menus']['study'] = array('name' => '学校生活',
    'submenu' => array(
    'study/translate' => array('name' => '翻译一下', 'link' => 'study/translate'),
    'study/source' => array('name' => '分享资源', 'link' => 'study/source'),
    'study/method' => array('name' => '小谈学习', 'link' => 'study/method'),
    'study/cet' => array('name' => '查询四六级成绩', 'link' => 'study/cet'),
    )
    );
    // 校园名片
    $config['menus']['card'] = array('name' => '校园名片', 'link' => 'card/index'
    );
  2. 新建菜单类,Menu.php,并创建获取菜单配置数据的方法(貌似有点多余)/优化方法,修改为读取配置类,封装获取配置文件
    <?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
    class Menu{ /**
    * 获取菜单配置
    */
    public function get_menus($param) {
    $CI =& get_instance();
    $CI->config->load('menus');
    $menus = $CI->config->item('menus');
    return $menus;
    }
    }
  3. 控制器index.php 调用菜单类,获取菜单配置数据,赋值模板
    /**
    * 首页
    */
    function index() {
    //引入menu类,获取菜单配置
    $this->load->library('menu');
    $data['menus'] = $this->menu->get_menus();
    $this->load->view('index.html', $data);
    }
  4. 模板循环输出菜单
    <ul class="nav navbar-nav navbar-left">
    <li class="active">
    <a href="/"> <i class="glyphicon glyphicon-home"></i>
    </a>
    </li>
    <?php foreach ($menus as $menu): ?> <?php if ( ! isset($menu['submenu']) ): ?>
    <li>
    <a href="<?=site_url($menu['link'])?>"><?=$menu['name']?></a>
    </li>
    <?php else: ?>
    <li>
    <a href="" class="dropdown-toggle" data-toggle="dropdown" aria-expanded="false">
    <?=$menu['name']?>
    <span class="caret"></span>
    </a>
    <ul class="dropdown-menu" role="menu">
    <?php foreach ($menu['submenu'] as $link => $submenu): ?>
    <li>
    <a href="<?=site_url($submenu['link'])?>"><?=$submenu['name']?></a>
    </li>
    <?php endforeach ?>
    </ul>
    </li>
    <?php endif ?> <?php endforeach ?>
    </ul>

主页菜单部分没完成,困了。明天再配置

桂电在线-php-提取菜单到配置文件的更多相关文章

  1. 桂电在线-php-提取菜单到配置文件2

    继续昨晚没完成的主菜单模板: <!-- 菜单块 --> <div class="on-light" id="menus"> <?p ...

  2. 桂电在线-转变成bootstrap版3(记录学习bootstrap)

    继续上文 正文菜单 html: <!-- 菜单块 --> <div class="on-light" id="menus"> <s ...

  3. 桂电在线-转变成bootstrap版2(记录学习bootstrap)

    下载bootstrap框架https://github.com/twbs/bootstrap 或者 http://getbootstrap.com/ 拷贝模板 修改基本模板 语言zh-cn,标题,描述 ...

  4. 桂电在线-转变成bootstrap版

    由于angularjs的不熟悉,而且SEO需要学习更多东西,于是先采用bootstrap版本,毕竟工作上也需要使用bootstrap,然后参照视频教程学习. bootstrap 基本模板 <!D ...

  5. 桂电在线_微信公众平台开发之-运用angularjs显示学校公告新闻列表和详情页面

    折腾angularjs的感悟 几天折腾,总的来说看了很多博客,要么不是最新的技术文档,要么写得不够完整,因为别人是基于他们的理解写的技术博客代码不一定会贴完整,所以一旦你用的是最新的想要看完整的实例就 ...

  6. Ubuntu Linux 使用桂电校园网 上网

    2016年9月1日 星期四 桂电校园网今天升级新的出校器,旧的出校器已经不能使用,所以本篇博客已经过期,下面的方法已经不能让Ubuntu使用桂电校园网上外网了.详细的原因,请到这个网站查看:校园网计费 ...

  7. GRUB2配置详解:默认启动项,超时时间,隐藏引导菜单,配置文件详解,图形化配置

    配置文件详解: /etc/default/grub # 设定默认启动项,推荐使用数字 GRUB_DEFAULT=0 # 注释掉下面这行将会显示引导菜单 #GRUB_HIDDEN_TIMEOUT=0 # ...

  8. 桂电在linux、Mac OS环境下使用出校器(支持2.14)

    这是guetsec学长在三院科协学长所抓包逆向分析1.81版出校器的基础上,用python写的一款为Mac和linux环境开发的出校器. 最后我做了略微修改,支持暂时最新版本2.14.下面有直接从源码 ...

  9. 桂电在linux环境下使用出校器

    一.官方出校器(无界面) 由于学校官方最新的linux版出校器无效,我们只能使用老版本的出校器了. 但因为老版本的出校器是32位的,而现在主流使用的是64位系统,因此我们得安装32位库. 在ubunt ...

随机推荐

  1. HOST1PLUS 的 VPS 主機-絕佳的性能和特惠的價格

    HOST1PLUS 的 VPS 主機-絕佳的性能和特惠的價格 undefined Open Container Project undefined 80后美女董事长吴艳:嫁得好不一定比干得好容易 - ...

  2. 小Q书桌的下载、安装和使用

    最近,无意之间,在某大牛电脑里,使用到了这款软件.感谢! 确实,挺实用和方便的,强烈推荐!!! 1.  下载 http://qdesk.qq.com/ 2.  安装 3.  使用 多么方便啊!

  3. 撸一个JS正则小工具

    写完正则在浏览器上检测自己写得对不对实在是不方便,于是就撸了一个JS正则小demo出来. demo demo展示 项目地址 代码部分 首先把布局样式先写好. <!DOCTYPE html> ...

  4. https_request请求接口返回数据

    定义一个https_request方法 <?php function https_request($url, $data = null) { $curl = curl_init(); curl_ ...

  5. Day 1 @ RSA Conference Asia Pacific & Japan 2016

    # 国内出发 早上8:45的航班,首次从深圳机场乘坐国际航班(先前去日本.欧洲都从香港走),就提前了3个小时出发. 乘taxi到机场30分钟不到,135元.到了T3 4号出发口,发现check-in的 ...

  6. 【原创】javascript——prototype与__proto__

    一定要注意这个概念:javascript世界里,万物皆对象, function是对象,prototyp也是对象.   新建构造函数,并实例 var Person = function(){} var ...

  7. [D3 + AngularJS] 15. Create a D3 Chart as an Angular Directive

    Integrating D3 with Angular can be very simple. In this lesson, you will learn basic integration as ...

  8. 一些as的配置

    打开Android Studio首选项对话框(Mac用户选择Android Studio菜单,Windows用户选择File → Settings菜单).分别展开Editor和Code Style选项 ...

  9. 高效 jquery 的奥秘

    当你准备使用 jQuery,我强烈建议你遵循下面这些指南: 1. 缓存变量 DOM 遍历是昂贵的,所以尽量将会重用的元素缓存. // 糟糕 h = $('#element').height(); $( ...

  10. Java基础知识强化之集合框架笔记63:Map集合之HashMap嵌套ArrayList

    1. ArrayList集合嵌套HashMap集合并遍历. 需求:假设ArrayList集合的元素是HashMap.有3个.每一个HashMap集合的键和值都是字符串.元素我已经完成,请遍历. 结果: ...