Сканирование адресов jquery - проблемы с логикой - PullRequest
1 голос
/ 21 сентября 2011

Я использую плагин jquery address для создания сайта, управляемого Ajax, и он у меня работает! Ура! Для целей этого вопроса мы можем использовать тестовый сайт:

http://www.asual.com/jquery/address/samples/crawling
http://www.asual.com/download/jquery/address
(Мне пришлось удалить два вызова на urlencode(), чтобы заставить работать пример сканирования.)

У меня проблема с вызовом $crawling->nav(). Он в основном использует js и php для загрузки частей XML-файла в dom. Я (в основном) понимаю, как это работает, и я хотел бы изменить пример кода, чтобы включить подстраницы.

Например, я хотел бы показать 'subnav-project.html' в '/!#/project' и '/!#/project/blue', но не в '/!#/contact'. Для этого я полагаю, что php должен «знать», на какой странице находится пользователь, чтобы я мог основывать свою логику на этом.

Это безумие? Может ли php узнать текущее состояние сайта, если я создаю его таким образом? Если нет, то как можно выборочно загружать фрагменты HTML или изменять ссылки, отображаемые в навигационных меню?

Раньше я никогда не сходил с ума от ajax, поэтому любая обратная связь была бы полезна.

EDIT

Это класс сканирования.

class Crawling { 

    const fragment = '_escaped_fragment_';

    function Crawling(){ 

        // Initializes the fragment value
        $fragment = (!isset($_REQUEST[self::fragment]) || $_REQUEST[self::fragment] == '') ? '/' : $_REQUEST[self::fragment];

        // Parses parameters if any
        $this->parameters = array();
        $arr = explode('?', $fragment);
        if (count($arr) > 1) {
            parse_str($arr[1], $this->parameters);
        }

        // Adds support for both /name and /?page=name
        if (isset($this->parameters['page'])) {
            $this->page = '/?page=' . $this->parameters['page'];
        } else {
            $this->page = $arr[0];
        }

        // Loads the data file
        $this->doc = new DOMDocument();
        $this->doc->load('data.xml');
        $this->xp = new DOMXPath($this->doc);
        $this->nodes = $this->xp->query('/data/page');
        $this->node = $this->xp->query('/data/page[@href="' . $this->page . '"]')->item(0);

        if (!isset($this->node)) {
            header("HTTP/1.0 404 Not Found");
        }
    }

    function base() {
        $arr = explode('?', $_SERVER['REQUEST_URI']);
        return $arr[0] != '/' ? preg_replace('/\/$/', '', $arr[0]) : $arr[0];
    }

    function title() {
        if (isset($this->node)) {
            $title = $this->node->getAttribute('title');
        } else {
            $title = 'Page not found';
        }
        echo($title);
    }

    function nav() {
        $str = '';

        // Prepares the navigation links
        foreach ($this->nodes as $node) {
            $href = $node->getAttribute('href');
            $title = $node->getAttribute('title');
            $str .= '<li><a href="' . $this->base() . ($href == '/' ? '' : '?' . self::fragment . '=' .html_entity_decode($href)) . '"' 
                . ($this->page == $href ? ' class="selected"' : '') . '>' 
                . $title . '</a></li>';
        }
        echo($str);
    }

    function content() {
        $str = '';

        // Prepares the content with support for a simple "More..." link
        if (isset($this->node)) {
            foreach ($this->node->childNodes as $node) {
                if (!isset($this->parameters['more']) && $node->nodeType == XML_COMMENT_NODE && $node->nodeValue == ' page break ') {
                    $str .= '<p><a href="' . $this->page . 
                        (count($this->parameters) == 0 ? '?' : '&') . 'more=true' . '">More...</a></p>';
                    break;
                } else {
                    $str .= $this->doc->saveXML($node);
                }
            }
        } else {
            $str .= '<p>Page not found.</p>';
        }

        echo(preg_replace_callback('/href="(\/[^"]+|\/)"/', array(get_class($this), 'callback'), $str));
    }

    private function callback($m) {
        return 'href="' . ($m[1] == '/' ? $this->base() : ($this->base() . '?' . self::fragment . '=' .$m[1])) . '"';
    }
}

$crawling = new Crawling();

1 Ответ

0 голосов
/ 21 сентября 2011

Вы не сможете принимать решения на стороне сервера, используя идентификатор фрагмента (т. Е. Все справа от символа #).Это связано с тем, что браузеры не отправляют на сервер идентификаторы фрагментов.Если вы хотите принимать решения на стороне сервера, вам нужно использовать некоторую помощь JavaScript (включая AJAX), чтобы сообщить, каков текущий идентификатор фрагмента.

...