Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
11 / 11 / 4
Регистрация: 17.06.2010
Сообщений: 438

Создание удобной навигации

03.05.2013, 23:50. Показов 1349. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Незнаю правильно ли это называть навигацией. Но как сделать чтобы динамически создавались номера страниц? Как пример на этом сайте картинка ниже. Или как это правильно называется, какие статьи, темы почитать, что в поисковике ввести?
Миниатюры
Создание удобной навигации  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.05.2013, 23:50
Ответы с готовыми решениями:

Отображение списка листов в столбик (или иной способ навигации удобной)
Доброго дня. Собственно, сабж отображен в заголовке. Буду благодарен любому совету, и вообще, возможно ли это? Проблема в чем - у...

Создание удобной среды пользователя в Аксесс
Приветствую. Начну с начала. У меня автомойка. Есть необходимость создания интерактивной базы данных клиентов. Покупать специалную...

Создание навигации
Здавствуйте! Я создала навигацию в программе open Cube - Nav Studio после этого скопировала код и вставила в html-страницу но...

2
17 / 13 / 2
Регистрация: 18.10.2012
Сообщений: 136
04.05.2013, 12:32
"Создание постраничной навигации"
1
11 / 11 / 4
Регистрация: 17.06.2010
Сообщений: 438
04.05.2013, 18:53  [ТС]
Лучший ответ Сообщение было отмечено TYMON как решение

Решение

вот кое-что написал, но чтото не работает, выводит каждую новость по 4 раза, а создает вторую страницу а там по каждую новость по 2 раза. Всего новостей 6. Делаю чтобы было по 4 новости на странице (для демонстрации достаточно)

Исходный код
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
<?php
include ("parts/connect.php");
$base_data=mysql_query("SELECT * FROM statii", $base_connect);
$page_data=mysql_fetch_array($base_data); //массив данных
?>
<!doctype html>
<html>
<head>
<meta charset="windows_1251">
<title>Футбольные новости</title>
<link href="css/mainstylecss.css" rel="stylesheet" type="text/css">
</head>
 
<body>
<div id="outer_wrapper">
<!--Header!-->
<?php
include ("parts/header.php")
?>
 
<!--Menu-->
<?php
include ("parts/menu.php")
?>
 
<div id="container" >
 
<div id="main" align="center">
<?php
do
// Выводим новости
{
    
    // Считаем общее количество новостей
    $resultrows = mysql_query("SELECT `id` FROM `statii`");
    $rows = mysql_num_rows($resultrows);
 
    // Пишем количество выводимый новостей на страницу, в нашем случае - 10
    $messages_per_page = 4;
 
    // Условие: если запрос GET не существует или он не является числом, то присваеваем ему значение 0
    if (!isset($_GET['rowstart']) || !preg_match("/^[0-9]+$/", $_GET['rowstart'])) 
    {
        $_GET['rowstart'] = 0;
    }
 
    // Выводим по 4 новости на страницу, где начальной точкой отсчета будет считаться запрос GET
    $result = mysql_query("SELECT * FROM `statii` ORDER BY `id` DESC LIMIT ".$_GET['rowstart'].",".$messages_per_page);
    while ($data = mysql_fetch_assoc($result))
     {
        //связываем с id материала
    printf("<div id='blog'>
    <table>
    <tr >
    <td colspan=5><a href='podrobnee.php?id=%s'>%s</a><br></td>
        </tr>
        <tr>
    <td colspan=5> %s<br></td>
    </tr>
    <tr>
        <td align=center>%s &nbsp; &nbsp %s &nbsp; &nbspПросмотров&nbsp;%s </td>
        <td> <a href='podrobnee.php?id=%s'>Подробнее</a></td>
        </tr>
    </table>
    <hr />
    </div>", $page_data["id"], $page_data["title"], $page_data["introtext"],
    $page_data["author"], $page_data["date_sozd"], $page_data["views"], $page_data["id"]);
    
}
 
    // Условие: если общее количество страниц больше, чем нам надо вывести (т.е. больше 10), то выводим список страниц
    if ($rows > $messages_per_page)
     {
        echo makepagenav($_GET['rowstart'], $messages_per_page, $rows, 3, $PHP_SELF."?&amp;");
    }
 
}
while ($page_data=mysql_fetch_array($base_data));   
?>
 
</div> <!--Main close!-->
 
 <!--Lastnews-->
<?php
include ("parts/lastnews.php")
?>
 
 
<!--Aside-->
<?php
include ("parts/aside.php")
?>
 
 
 
</div>
 <!--Container close!-->
 
 
<!--Footer-->
<?php
include ("parts/footer.php")
?>
 
</div> <!--Out_Wrapper close!-->
</body>
</html>

код php:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<?
// Функция постраничной навигации
function makepagenav($start, $count, $total, $range = 0, $link) 
{
    if ($link == "") { $link = $PHP_SELF."?"; }
    $pg_cnt = ceil($total / $count);
    if ($pg_cnt <= 1) { return ""; }
    $idx_back = $start - $count;
    $idx_next = $start + $count;
    $cur_page = ceil(($start + 1) / $count);
    $res = "Страница ".$cur_page." из ".$pg_cnt.": ";
    if($idx_back >= 0) {
        if($cur_page > ($range + 1)) {
            $res .= "<a href='".$link."rowstart=0'>1</a>...";
        }
    }
    $idx_fst = max($cur_page - $range, 1);
    $idx_lst = min($cur_page + $range, $pg_cnt);
    if ($range == 0) {
        $idx_fst = 1;
        $idx_lst = $pg_cnt;
    }
    for ($i = $idx_fst; $i <= $idx_lst; $i++) {
        $offset_page = ($i - 1) * $count;
        if ($i == $cur_page) {
            $res .= "<span><strong>".$i."</strong></span>";
        } else {
            $res .= "<a href='".$link."rowstart=".$offset_page."'>".$i."</a>";
        }
    }
    if ($idx_next < $total) {
        if ($cur_page < ($pg_cnt - $range)) {
            $res .= "...<a href='".$link."rowstart=".($pg_cnt - 1) * $count."'>".$pg_cnt."</a>";
        }
    }    
    return "<div>".$res."</div>";
}
 
 
//соеденение с БД
$base_location="localhost";
$base_name="football";
$base_user="root";
$base_password="";
 
$base_connect = mysql_connect ($base_location, $base_user, $base_password);
mysql_select_db ($base_name, $base_connect);
mysql_query ("set character_set_client='cp1251'"); //кодировка, в которой данные будут поступать от клиента
mysql_query ("set character_set_results='cp1251'"); //кодировка, в которой будет выбран результат
mysql_query ("set collation_connection='cp1251_general_ci'");
if (!$base_connect)
{
    echo("<p>Ошибка!!! Невозможно подключиться к базе данных!!!</p>");
    exit();
}
?>
Где то я что-то напутал не могу понять где

Добавлено через 4 часа 43 минуты
если нужно кинуть весь проект я кину, если кто-то может помочь
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.05.2013, 18:53
Помогаю со студенческими работами здесь

Создание кнопок навигации
Здравствуйте. Я пытаюсь создать навигационное меню на сайте. Структура такая: &lt;table&gt;&lt;tr&gt; &lt;td...

Создание кнопок навигации и печати
Здравствуйте, помогите пожалуйста в решении вот какой задачи. Необходимо создать кнопки навигации по книге, т.е. отдельную кнопку для...

Создание кнопок навигации и печати без макросов и vba
Здравствуйте, помогите пожалуйста в решении вот какой задачи. Необходимо создать кнопки навигации по книге, т.е. отдельную кнопку для...

Выбор удобной IDE for Ruby
Здравствуйте. Совсем недавно познакомился с таким зверьком, как ruby. Ну и затянуло по самые я.. т е уши.:) Ну блокнотом сыт не будешь....

Выбор компонента для удобной работы
Ребят подскажите, каким компонентом удобнее и легче всего реализовать... Суть задачи: Загружаю из файла примерно 20 строк... И что бы...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды "Заполнить" и "Очистить" на форме документа
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". На примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных выбран регистр накопления, в. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru