views:

56

answers:

3

Fairly new to CodeIgniter, still grasping the MVC approach. I'm just wondering what's the best way to solve this:

I got my navigation bar highlighting the currently active link like so:

<a href="index.hml" id="active">Index</a>
<a href="blog.hml">Blog</a>

Now, when I go to blog.html I want id="active" to shift accordingly. Usually I'd assign a variable to each link and then set it's value to 'id="active'. Somehow I don't think that's the best way. Any thoughts?

+3  A: 

Non-specific to CI this is just logical checks agains the current page name.

When you get the page name in CI such as

$pageName = 'blog.html';

Then you can do the following

<a href="index.html" <?php echo $pageName == 'index.html' ? 'id="active"' : ''; ?>>Index</a>
<a href="blog.html" <?php echo $pageName == 'blog.html' ? 'id="active"' : ''; ?>>Blog</a>
Paul Dragoonis
A: 

First of all you should not be using id for that kind of things, id is to give a unique identification number to each DOM element on the page, for what, we best use a class.

Code Igniter provides a lot of helpers and classes that become part our tools, probably you have heard of "URL Segments" before.

$this->uri->segment(n)

Permits you to retrieve a specific segment. Where n is the segment number you wish to retrieve. Segments are numbered from left to right. For example, if your full URL is this:

*http://example.com/index.php/news/local/metro/crime_is_up*

The segment numbers would be this:

  1. news
  2. local
  3. metro
  4. crime_is_up

http://codeigniter.com/user_guide/libraries/uri.html

you can use that to retrieve the current URL segment that represents the Active Page you are actually displaying on the browser.

GerManson
-1. Why using JavaScript when server side solution is so easy (see Paul Dragoonis answer)?
MainMa
It works, althrough I couldn't use Paul's shorter format in localhost, still good 'old <?php if ($pageName == 'index') echo 'id="active"'; ?>
Ando
My method still applies, you just need to get $pageName from CI possibly using the 'uri' object depending on how your app is built.
Paul Dragoonis
A: 

I saw from the comment made above that perhaps you were looking for something a little bit more compact. There isn't a function like that in Codeigniter by default, but it's easy enough to make one. This is just something I put together as of now, but it might be what you want to have.

First, take a look at the URL helper in the manual. http://codeigniter.com/user_guide/helpers/url_helper.html

Look specifically at the anchor function and understand how to use. You should be in the habit to use this helper, the HTML helper and the form helper. It will improve your views. All the helpers are available for us in the system folder. What I did was I just opened up the URL helper and copied the anchor code, I then created my own helper file in the helper folder under application. You can read more about creating your own helpers and autoloading them in the manual.

I then made a few changes to it. The final result looks like this:

if ( ! function_exists('menu_anchor'))
{
    function menu_anchor($uri = '', $title = '', $attributes = '')
    {
        $title = (string) $title;

        if ( ! is_array($uri))
        {
            $site_url = ( ! preg_match('!^\w+://! i', $uri)) ? site_url($uri) : $uri;
        }
        else
        {
            $site_url = site_url($uri);
        }

        if ($title == '')
        {
            $title = $site_url;
        }

        if ($attributes != '')
        {
            $attributes = _parse_attributes($attributes);
        }

    $attributes .= ($site_url == current_url()) ? ' selected' : '';

        return '<a href="'.$site_url.'"'.$attributes.'>'.$title.'</a>';
    }
}

As you can see, it's only a one line modification: $attributes .= ($site_url == current_url()) ? ' selected' : '';

Basically, if the URL of the retrieved page matches the papge that the anchor links to, it adds the class selected. If you don't want the selected link to link anywhere specific, you can easily fix this as well by setting $site_url to # or something else.

Calle