Codeigniter路由帮助,反向链接到以前的目录

时间:2014-12-23 18:12:58

标签: php codeigniter codeigniter-routing

相关网站为http://www.ziplinegolive.com/

我在CI中构建了这个,目前有2个“views”文件夹

-pages 和 -news

我想创建一个新闻目录来整理我的帖子,而不是让他们干扰其他页面。我遇到的问题是,一旦我进入http://www.ziplinegolive.com/news/home,我注意到当我检查我的标题链接时...所有的网址都获取了新闻/目录......这样我就可以回去了....有谁知道我怎么解决这个问题?我目前有一个路由配置文件和2个控制器。

首先是我的routes.php

$route['news/(:any)'] = 'news/view/$1';
$route['(:any)'] = 'pages/view/$1';
$route['default_controller'] = 'pages/view';

这是我的标准页面控制器

<?php

class Pages extends CI_Controller {

public function view($page = 'home')
{
  if ( ! file_exists(APPPATH.'/views/pages/'.$page.'.php'))
{
    // Whoops, we don't have a page for that!
    show_404();
}

$data['title'] = ucfirst($page); // Capitalize the first letter

$this->load->view('templates/header', $data);
$this->load->view('pages/'.$page, $data);
$this->load->view('templates/footer', $data);

}
}

这是我的新闻控制器

<?php
class News extends CI_Controller {

    public function view($page = 'home')
{

    $data['title'] = ucfirst($page); // Capitalize the first letter

  $this->load->view('templates/header', $data);
  $this->load->view('news/'.$page);
  $this->load->view('templates/footer', $data);


}

}

我一直在竭尽全力试图解决这个问题....任何帮助都非常感谢!

谢谢你!

UPDATE:ADDED HEADER.PHP - 正如你所看到的那样,css和js文件是静态链接的,因为这个路由崩溃......

<!doctype html>
<html class="no-js" lang="en">
<head>
 <meta charset="utf-8">
 <title>ZipLine™</title>
 <meta name="apple-mobile-web-app-capable" content="yes">
 <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0,    user-scalable=no" />
 <meta name="HandheldFriendly" content="true" />
 <meta name="apple-touch-fullscreen" content="yes" />
 <!-- All Animations CSS -->
 <link href="http://www.ziplinegolive.com/css/animate.css" rel="stylesheet" type="text/css">
 <!-- Image Lightbox CSS-->
 <link rel="stylesheet" href="http://www.ziplinegolive.com/css/imagelightbox.css"      type="text/css" media="screen">
 <!-- Theme styles and Menu styles -->
 <link href="http://www.ziplinegolive.com/css/style.css" rel="stylesheet" type="text/css">
 <link href="http://www.ziplinegolive.com/css/mainmenu.css" rel="stylesheet" type="text/css">
 <!-- Call Fontawsome Icon Font from a CDN -->
 <link href="http://netdna.bootstrapcdn.com/font-     awesome/4.1.0/http://www.ziplinegolive.com/css/font-awesome.min.css" rel="stylesheet">
 <link rel="stylesheet" href="js/jquery.fancybox.css" type="text/css" media="screen">

 <!--FlexSlider -->
 <link rel="stylesheet" href="js/woothemes-FlexSlider-06b12f8/flexslider.css"      type="text/css" media="screen">
 <!--Isotope Plugin -->
 <link rel="stylesheet" href="js/isotope/http://www.ziplinegolive.com/css/style.css"      type="text/css" media="screen">
 <!--Simple Text Rotator -->
 <link href="http://www.ziplinegolive.com/css/simpletextrotator.css" rel="stylesheet" type="text/css">
 <!--Modernizer Custom -->
 <script type="text/javascript" src="js/modernizr.custom.48287.js"></script>
 <!-- Fav and touch icons -->
 <link rel="apple-touch-icon-precomposed" sizes="114x114" href="apple-touch-icon-114x114-precomposed.png">
 <link rel="apple-touch-icon-precomposed" sizes="72x72" href="apple-touch-icon-72x72-precomposed.png">
 <link rel="apple-touch-icon-precomposed" href="apple-touch-fa-57x57-precomposed.png">
 <link rel="shortcut icon" href="favicon.png">
 </head>
 <body class="sticky_header">
 <div class="overflow_wrapper">
 <header>
      <div class="container">
           <div class="logo"><a class="brand" href="index.html"><img      src="http://www.ziplinegolive.com/images/logo.png" alt="optional logo"></a></div>

           <!-- MAIN MENU -->

           <div id="mainmenu" class="menu_container">
                <label class="mobile_collapser">MENU</label>
                <!-- Mobile menu title -->
                <ul>
                     <li class="active"><a href="index.html">Home</a></li>
                     <li><a href="#">About Us</a>
                     <div class="dmui_dropdown_block">
                               <ul class="dmui-submenu">
                                    <li><a href="about">The Company</a></li>
                                    <li><a href="media">Media</a></li>
                                    <li><a href="partners">Partners</a></li>
                               </ul>
                          </div>

                     </li>
                      <li><a href="products">Products and Services</a></li>
                     <li><a href="news">News</a></li>
                     <li><a href="contact">Contact</a></li>
                </ul>
           </div>

           <!-- /MAIN MENU -->

           <div class="triangle-up-left"></div>
           <div class="triangle-up-right"></div>
      </div>
 </header>

1 个答案:

答案 0 :(得分:1)

更改链接。

例如

<li><a href="about">The Company</a></li> 
=> 
<li><a href="<?php echo site_url('about');?>">The Company</a></li>

此外,您可以链接到这样的css / js文件:

 <link href="<?php echo base_url('assets');?>/css/mainmenu.css" rel="stylesheet" type="text/css">

这当然要求你在project / assets / css中有你的css文件