С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
0 / 0 / 0
Регистрация: 31.03.2017
Сообщений: 91
1

Строка не выделяется

07.04.2017, 11:21. Показов 1635. Ответов 11
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть таблица товаров и нужно было сделать так : когда остаток товаров остается меньше 10 покрасить строку в другой цвет тем самым выделить строку собственно код
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
include('../connect.php');
                               
                                $result = $db->prepare("SELECT *, price * qty as total FROM products ORDER BY product_id DESC");
                                $result->execute();
                                for($i=0; $row = $result->fetch(); $i++){
                                $total=$row['total'];
                                $availableqty=$row['qty'];
                                if ($availableqty < 10) {
                                echo '<tr class="alert alert-warning record" style="color: #fff; background:rgb(255, 95, 66);">';
                                }
                                else {
                                echo '<tr class="record">';
                                }                       ?>
Этот код не работает почему то. Точнее до этого работал но я добавил ещё один столбец в таблицу и сделал изменения в файле обработчика после этого перестал работать. Убрал столбец , но скрипт так же по прежнему не работает
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.04.2017, 11:21
Ответы с готовыми решениями:

Не выделяется строка
добрый день! Подскажите как сделать чтобы при добавлении в датагрид он выделял добавленную строку?...

Не выделяется строка таблицы
Добрый день. При обработке клика на строку не выделяется нужная строка после сортировки. Для...

Не выделяется цветом строка в RichEdit
procedure TForm1.Button2Click(Sender: TObject); var i: integer; begin for i:=0 to...

Почему не выделяется строка стринггрида (TStringGrid)?
with tstringgrid(sender)do begin CanSelect:=True; ...

11
(ノಠ益ಠ)ノ彡┻━┻
152 / 152 / 78
Регистрация: 05.06.2014
Сообщений: 710
Записей в блоге: 2
08.04.2017, 18:04 2
localghost, у вас не хватает закрывающей скобки для цикла
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
include ('../connect.php');
 
$result = $db->prepare("SELECT *, price * qty as total FROM products ORDER BY product_id DESC");
$result->execute();
 
for ($i = 0; $row = $result->fetch(); $i++) {
  $total = $row['total'];
  $availableqty = $row['qty'];
  if ($availableqty < 10) {
    echo '<tr class="alert alert-warning record" style="color: #fff; background:rgb(255, 95, 66);">';
  }
  else {
    echo '<tr class="record">';
  }
}
И непонятно что выводит echo, вы в нем только открываете теги tr, но внутри нет ни td с данными, ни закрывающего тега...
1
0 / 0 / 0
Регистрация: 31.03.2017
Сообщений: 91
10.04.2017, 13:35  [ТС] 3
Да спасибо N3stY, исправил )
0
0 / 0 / 0
Регистрация: 31.03.2017
Сообщений: 91
14.04.2017, 18:25  [ТС] 4
N3stY, Закрывающая скобка после таблицы тут ее не видно. А echo выводит если количество товара меньше 10 шт в базе то покрасить строку к красный цвет иначе если все нормально следовать дальше по умолчанию )
0
(ノಠ益ಠ)ノ彡┻━┻
152 / 152 / 78
Регистрация: 05.06.2014
Сообщений: 710
Записей в блоге: 2
14.04.2017, 18:37 5
Цитата Сообщение от localghost Посмотреть сообщение
Закрывающая скобка после таблицы тут ее не видно.
В смысле?

Цитата Сообщение от localghost Посмотреть сообщение
товара меньше 10 шт в базе то покрасить строку
Не уловил суть, у вас не перебирается массив результатов ил как? Делайте через while, а не for

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
include ('../connect.php');
 
$result = $db->prepare("SELECT *, price * qty as total FROM products ORDER BY product_id DESC");
$result->execute();
 
while ($row = $result->fetch(PDO::FETCH_ASSOC)) {
  $total = $row['total'];
  $availableqty = $row['qty'];
  if ($availableqty < 10) {
    echo '<tr class="alert alert-warning record" style="color: #fff; background:rgb(255, 95, 66);">...</tr>'; // "Красим"
  }
  else {
    echo '<tr class="record">...</tr>'; // Оставляем как есть
  }
}
0
0 / 0 / 0
Регистрация: 31.03.2017
Сообщений: 91
15.04.2017, 09:15  [ТС] 6
N3stY, знаете что странного во всём этом ? Так это вышеуказанная "конструкция" работала точнее вышеуказанный код работал , но стоило мне добавить ещё один столбец в табличку так она и перестала работать. ) Сам не понимаю в чем дело , вроде все написано правильно и до этого все работал а теперь вот тебе и раз )
А насчет закрывающей скобки так она внизу таблицы т е далее вышеуказанного кода есть таблица и под ним и поставил закрывающую скобку ) Здесь не стал приводить думал не важно. Но думаю стоит все таки
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
<?php include('../connect.php');
                
                $result = $db->prepare("SELECT *, price * qty as total FROM products ORDER BY product_id DESC");
                $result->execute();
                for($i=0; $row = $result->fetch(); $i++){
                $total=$row['total'];
                $availableqty=$row['qty'];
                if ($availableqty < 10) {
                echo '<tr class="alert alert-warning record" style="color: #fff; background:#FF0000;">';
                }
                else {
                echo '<tr class="record">';
                }
                
            ?>
        
 
      <tr>
        <td><?php echo $row['product_code']; ?></td>
            <td><?php echo $row['gen_name']; ?></td>
            <td><?php echo $row['product_name']; ?></td>
                        <td><?php echo $row['catg']; ?></td>
 
              <td><?php echo $row['supplier']; ?></td>
            <td><?php echo $row['date_arrival']; ?></td>
            <td><?php echo $row['expiry_date']; ?></td>
            <td><?php
            $oprice=$row['o_price'];
            echo formatMoney($oprice, true);
            ?></td>
            <td><?php
            $pprice=$row['price'];
            echo formatMoney($pprice, true);
            ?></td>
            <td><?php echo $row['qty_sold']; ?></td>
            <td><?php echo $row['qty']; ?></td>
            <td>
            <?php
            $total=$row['total'];
            echo formatMoney($total, true);
            ?>
            </td>
            <td><?php echo $row['fakturanumber']; ?></td>
            <td><?php echo $row['sdate']; ?></td>
            <td><?php echo $row['ediz']; ?></td>            
            <td><a rel="facebox" title="Редактировать" href="editproduct.php?id=<?php echo $row['product_id']; ?>"><button class="btn btn-warning"><i class="icon-edit"></i> </button> </a>
            <a href="#" id="<?php echo $row['product_id']; ?>" class="delbutton" title="Удалить"><button class="btn btn-danger"><i class="icon-trash"></i></button></a></td>
        </tr>
            <?php
                }
            ?>
Добавлено через 1 минуту
Прошу не обращать внимания на "некрасивый" код , сделал просто как смог )
0
Заблокирован
15.04.2017, 10:35 7
Зачем второй раз строку таблицы открываете?

Добавлено через 9 минут
Чтобы не было такого хибарного самостроя, меняйте класс (в тегах стили лучше не прописывать явно) внутри тега tr ветвлением или тернарным оператором:
PHP/HTML
1
<tr class="<?php if ($row['qty']<10): ?>alert alert-warning <?php endif; ?>record">
PHP/HTML
1
<tr class="<?= $row['qty']<10?'alert alert-warning ':'' ?>record">
Выше этого сразу заголовок цикла альтернативным синтаксисом:
PHP
1
<?php for($i=0; $row = $result->fetch(); $i++): ?>
Если счетчик не нужен, используйте цикл while, как выше сказали.

Работать с базой, т.е. делать выборку из базы нужно гораздо раньше.
1
(ノಠ益ಠ)ノ彡┻━┻
152 / 152 / 78
Регистрация: 05.06.2014
Сообщений: 710
Записей в блоге: 2
15.04.2017, 12:50 8
Лучший ответ Сообщение было отмечено localghost как решение

Решение

localghost, у вас выходит два тега <tr>, поэтому и форматирования нет. Строка 18 в вашем посте

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php
include ('../connect.php');
 
$result = $db->prepare("SELECT *, price * qty as total FROM products ORDER BY product_id DESC");
$result->execute();
 
for ($i = 0; $row = $result->fetch(); $i++) {
  $total = $row['total'];
  $availableqty = $row['qty'];
  if ($availableqty < 10) {
    echo '<tr class="alert alert-warning record" style="color: #fff; background:#FF0000;">';
  }
  else {
    echo '<tr class="record">';
  }
 
?>
<tr> <- этот
  <td>
    <?php
    echo $row['product_code']; ?>
  </td>
1
0 / 0 / 0
Регистрация: 31.03.2017
Сообщений: 91
15.04.2017, 13:52  [ТС] 9
N3stY, Спасибо Вам большое ! Убрал этот tr и все стало по местам )

Добавлено через 1 минуту
miketomlin, спасибо. А сможете обьяснить есть ли разница начать работу с БД раньше или потом ? Так как до этого не обращал внимания не это ...(
0
(ノಠ益ಠ)ノ彡┻━┻
152 / 152 / 78
Регистрация: 05.06.2014
Сообщений: 710
Записей в блоге: 2
15.04.2017, 15:04 10
Цитата Сообщение от localghost Посмотреть сообщение
PHP
1
for($i=0; $row = $result->fetch(); $i++){
и всё же используйте лучше while, так будет корректнее и код меньше
PHP
1
while($row = $result->fetch(PDO::FETCH_ASSOC)) {
или так
PHP
1
<?php while($row = $result->fetch(PDO::FETCH_ASSOC)): ?>
0
0 / 0 / 0
Регистрация: 31.03.2017
Сообщений: 91
16.04.2017, 12:27  [ТС] 11
N3stY, Да уже перешел на while. А не подскажете как сделать выборку из двух таблиц на одной странице ? Если писать два запроса один за другим он у меня выполняет последний...
0
(ノಠ益ಠ)ノ彡┻━┻
152 / 152 / 78
Регистрация: 05.06.2014
Сообщений: 710
Записей в блоге: 2
16.04.2017, 15:49 12
localghost, примерно так

PHP
1
2
3
4
5
6
7
8
9
10
$result = $db->prepare("SELECT *, price * qty as total FROM products ORDER BY product_id DESC");
$result->execute();
$row = $result->fetchAll(PDO::FETCH_ASSOC);
 
foreach ($row as $r) {
  $result2 = $db->prepare("SELECT * table WHERE id='{$r['id']}'");
  $result2->execute();
  $row2 = $result2->fetch(PDO::FETCH_ASSOC);
  # code...
}
0
16.04.2017, 15:49
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.04.2017, 15:49
Помогаю со студенческими работами здесь

Не выделяется первая строка полностью после фиксированной в StringGrid
Здравствуйте!!! Ребята, подскажите. Хочу чтобы выделялась полностью первая строка в StringGrid...

Если память для объекта выделяется динамически (строка 33), сортировка sort не работает
Если память для объекта выделяется динамически (строка 33), сортировка sort не работает, если...

RichMemo: должна выделяться жирным только первая строка, а выделяется почти весь текст
должна выделяться жирным только первая строка, а выделяется почти весь текст! почему? что надо...

Не выделяется память
#ifndef _STUDENT_ #define _STUDENT_ namespace Schools { class Student { public:...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru