Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: помогите с checkbox
 
 автор: nir555   (28.12.2006 в 13:56)   письмо автору
 
 

привет всем!

искал по форуму, про checkbox'ы много сказано, но вот что то подходящее не нашлось ( может не там искал )

проблема в следующем:
имеется файл phpследующего содержания
<?php
$mysql_host = "localhost"; // хост
$db_name = "111"; // база данных
// при коннекте к локальному хосту логин и пароль не нужен
$mysql_login = "222"; // логин
$mysql_password = "333"; // пароль
// коннектимся к мускульной бд
$link = mysql_connect("$mysql_host", "$mysql_login", "$mysql_password") or die ("Нет соединения с хостом");

$dn="$_POST[dn]";
$dk="$_POST[dk]";

print (" <head> ");
print (" <title>пробная страничка</title>");
print (" </head>");
print (" <body>");
print (" <h3>Статистика по запросам за период: ".$dn." по ".$dk." </h3>");
print (" <form method='post'>");
print (" Дата начала&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;");
print (" <input type=text name = dn value=".$dn.">");
print (" <br>");
print (" Дата окончания");
print (" <input type=text name = dk value=".$dk."> ");
print (" <br>");
print (" <input type=submit>");
print (" </form>");
print(" ".$dn." ");
print(" ".$dk." ");
print (" </body>");
// создается переменная в котрую вписывается запрос к мускулю
$query = "select
*
from message_in
where
dateTime between '$dn' and '$dk'
and
sms regexp '^[[:space:]]*33 '";
// отправляется запрос и затем сохраняется в переменной
$result = mysql_db_query ($db_name, $query);
print ("<TABLE BORDER=1 WIDTH=\"75%\" ,CELLSPACING=2
~CELLPADDING=2 ALIGN=CENTER>\n");
print ("<TR ALIGN=CENTER VALIGN=TOP>\n");
print ("<TD ALIGN=CENTER VALIGN=TOP>показать</TD>\n");
print ("<TD ALIGN=CENTER VALIGN=TOP>DateTime </TD>\n");
print ("<TD ALIGN=CENTER VALIGN=TOP>address </TD>\n");
print ("<TD ALIGN=CENTER VALIGN=TOP>message</TD>\n");
print ("</TR>\n");
// создается цикл который по строчно вытаскивает данные с мускуля
while ($Row = mysql_fetch_array ($result)) {
print ("<form action=\"obrabotka.php\" method=\"post\">");
print ("<TR ALIGN=CENTER VALIGN=TOP>\n");
print ("<TD ALIGN=left VALIGN=TOP><input type=\"checkbox\" name=\"\" value=\"\"></TD>\n") ;
print ("<TD ALIGN=left VALIGN=TOP>".$Row[DateTime]."</TD>\n") ;
print ("<TD ALIGN=left VALIGN=TOP>".$Row[addr]."</TD>\n");
print ("<TD ALIGN=left VALIGN==TOP>".$Row[message]."</TD>\n");
print ("</TR>\n");
}
print ("<input type=\"submit\" value=\"показать\">");
print ("</form>\n");
print ("</TABLE>");
print ("</body>");
?>

он выводит в таблицу данные из mysql дата , адреси сообщение,
также в каждой строке в первом столбце есть флажок checkbox ,
пользователь проставляет флажки и далее жмет "показать" и в следующей страничке остается только ячейки message, из строк которые были помеченны флажками.

подскажите плиз как это будет лучше реализовать. :-)

   
 
 автор: LuxeMate   (28.12.2006 в 14:13)   письмо автору
 
   для: nir555   (28.12.2006 в 13:56)
 

Идея такая:
Вам нужно добавить в таблицу поле id,и у каждого чекбокса зделать значением id сообщения,далее вы отмечаете те сообщения которые хотите увидеть,и передаёте методом поста значения чекбоксов,далее в цикле вам нужно будет зделать mysql_query и выбрать сообщения по id которые вы передали в чекбоксе))...

   
 
 автор: ozono   (28.12.2006 в 14:14)   письмо автору
 
   для: nir555   (28.12.2006 в 13:56)
 

слушай дай чекбоксу нейм!!!!!

чекбокс проверяют так


if (isset($_POST['check-name'])){ ..... code...}


означает что если чекбокс отмечен то сделает нужный код!

   
 
 автор: nir555   (01.01.2007 в 16:24)   письмо автору
 
   для: ozono   (28.12.2006 в 14:14)
 

Всех с наступившим!!! :-)

LuxeMate и ozono спасибо за помощь,

в моей форме n - ое количество чекбоксов и заранее оно не изветсно,

я попробовал метод который посаветовал мне ozono, все заработало только, он выдает значение последнего из отмеченных чекбоксов, пробовал сделать массив со значениями отмеченных чек боксов,массив вроде как поличился, но толи пустой, толи просто я не правильно пытаюсь вывести данные из массива, а делал я следущее


<?php
    
if (isset($_POST[vid]))
    {
    
    
$vid= array ("$_POST[vid]") ;
    for (
$n0$n count($vid); $n++)
    {  
$line each ($vid);
    print (
" ".$line[value]."<P>\n ");} 
        
    }
    else 
    {
    print (
" нет  чеков ");
     }        

?>


подскажите плиз, что я не так делаю ?

   
 
 автор: LuxeMate   (01.01.2007 в 18:40)   письмо автору
 
   для: nir555   (01.01.2007 в 16:24)
 

Ужас))


<?php
if(isset($_POST['vid'])){
$vid_ch $_POST['vid'];
 for(
$i=0;$i=count($vid_ch);$i++){
 print(
" ".$vid_ch[$i]."<P>\n "); //тут должны отобразиться все значения чекбоксов которые вы отметите
 
}
}else{ 
print(
" нет  чеков ");

?>

А чтобы выбрать записи нада будет в mysql_query написать WHERE `поле`=$vid_ch[$i],на том месте где написано print(" ".$vid_ch[$i]."<P>\n ");

   
 
 автор: nir555   (01.01.2007 в 20:39)   письмо автору
 
   для: LuxeMate   (01.01.2007 в 18:40)
 

не выходит, один к одному копирую код вставляю в свой файл. при выполнении этого кода
в браузер выводится второй символ значеня из последнего отмеченного чекбокса и повторяется , затем internet explorer зависает и приходится его через диспечер задач отрубать. Вот такая вот картина :-( ?

   
 
 автор: LuxeMate   (01.01.2007 в 20:54)   письмо автору
 
   для: nir555   (01.01.2007 в 20:39)
 

Щас подумаю и чего нибудь отвечу))

   
 
 автор: LuxeMate   (01.01.2007 в 21:26)   письмо автору
 
   для: LuxeMate   (01.01.2007 в 20:54)
 

Ой,точно...извеняюсь,я немного напортачил в цикле))

<?php
if(isset($_POST['vid'])){
 for(
$i=0;$i<=count($_POST['vid']);$i++){
 print(
" ".$_POST['vid'][$i]."<P>\n "); //тут должны отобразиться все значения чекбоксов которые вы отметите
 
}
}else{ 
print(
" нет  чеков ");
}
?>

   
 
 автор: nir555   (01.01.2007 в 21:44)   письмо автору
 
   для: LuxeMate   (01.01.2007 в 21:26)
 

все, работает :-)
LuxeMate благодарю за помощь :-)

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования