DevProTalk

Forumi IT profesionalaca
web development, web design, e-business, SEO


Idite nazad   DevProTalk > Web development i web aplikacije > PHP
Želite da se reklamirate ekskluzivno na ovoj poziciji? Javite se

PHP PHP aplikacije, Smarty, PEAR

Odgovori
 
Alati teme Način prikaza
Staro 19. 09. 2013.   #1
slavkan
profesionalac
Professional
 
Datum učlanjenja: 30.08.2010
Poruke: 201
Hvala: 10
640 "Hvala" u 14 poruka
slavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished road
Default slozena forma i check box polja

Pozdrav, treba mi jedna mala pomoc. Necu da duzim evo odmah problema. Imam jednu tabelu u kojoj izlistavam naslove nekih vijesti i njihov status (objavljeno/neobjavljeno). Pored naslova vijesti i njihovog statusa stampam po jedan checkbox. Treba mi ideja kako da mijenjam status ovih vijesti u slucaju da sam checkirao vise njih. Npr cekiram 5 vijesti i hocu da na klik promijenim njihov status sa neobjavljeno na objavljeno. Evo postavicu html kod pa ce biti jasnije:

PHP kôd:
<thead>
                                <tr>
                                    <th style="width:6%">ИД </th>
                                    <th style="width:20%">Наслов</th>
                                    <th style="width:18%">Аутор</th>
                                    <th style="width:13%">Датум</th>
                                    <th style="width:13%">Тип вијести</th>
                                    <th style="width:13%">Објављено</th>
                                    <th style="width:15%">Управљање</th>
                                </tr>
                            </thead>

<tbody>
                    <?php
                                
require_once('../connection.php');
                                
                    
//SQL UPIST ZA CITANJE 
                                
$qry=$mysqli->set_charset("utf8");
                                
$qry="SELECT * FROM vijest";
                                        
                                
//IZVRSAVANJE SQL UPITA
                                
$result=$mysqli->query($qry) or die($mysqli->error.__LINE__);
                                
                                if(
$result->num_rows 0
                                {
                                    while(
$row $result->fetch_assoc()) 
                                    {
                            
?>
                        <!--Izlistavanje  vesti-->
<form action="" method="POST" name="form" enctype='multipart/form-data'>
                                        <tr>
                                            <td class="align-center"><?php echo $row['ID'];?></td>
                                            <td><?php echo '<a href="preview.php?idnews='.$row['ID'].'">';?><?php echo $row['naslov_vijesti'];?></a></td>
                                            <td><?php echo $row['autor_vijesti'];?></td>
                                            <td><?php echo $row['datum_vijesti'];?></td>
                                            <td><?php echo $row['tip_vijesti'];?></td>
                                            <td><?php echo $row['status_vijesti'];?></td>
                                            <td>
                                                <input type="checkbox" name="checkbox" value="<?php echo $row['ID'];?>"/>
                                                <a href=""><img src="pencil.gif" width="16" height="16" alt="edit" /></a>
                                                <input type="submit" name="submit" value="objavi">
                                                <!--<a href=""><img src="balloon.gif" width="16" height="16" alt="comments" /></a>
                                                <a href=""><img src="bin.gif" width="16" height="16" alt="delete" /></a>
                                                <a href=""><img src="tick-circle.gif" width="16" height="16" alt="published" /></a>-->
                                            </td>
                                        </tr>
                                        </form>
                            <?php            
                                    
}
                                }
                                else 
                                {
                                    echo 
'Нема резултата!';    
                                }
                            
?>        
                            </tbody>
                        </table>

 <div class="table-apply">
                           
                            <div>
                            <span>Примени на све вести:</span> 
                            <select class="input-medium" name="akcija">
                                <option value="1" selected="selected">Select action</option>
                                <option value="2">Објави</option>
                                <option value="3">Сакриј</option> 
                            </select>
                            <a href=""><img src="tick-circle.gif" width="16" height="16" alt="edit" /></a>
                            </div>
                            
                        </div>
Ukratko sta hocu:
Ako u toj tabeli imam izlistano 10 vesti, kada cekiram svih 10 i dole na dnu gde mi je select lista prebacim na Objavi da se u bazi promeni status. Dakle ne treba mi SQL skript nego samo ideja kako da, na klik dugmeta, pokupim ove $row('ID') svih cekiranih boxova. Ne znam kako da pridjem tim poljima u formi i da ih smestam u neki niz.
slavkan je offline   Odgovorite uz citat
Staro 19. 09. 2013.   #2
Nemanja Avramović
emperor Selassie
Grand Master
 
Avatar Nemanja Avramović
 
Datum učlanjenja: 20.10.2006
Lokacija: Mladenovac
Poruke: 754
Hvala: 361
576 "Hvala" u 88 poruka
Nemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoro
Pošaljite ICQ poruku za Nemanja Avramović Pošaljite poruku preko MSN za Nemanja Avramović Pošaljite poruku preko Yahoo za Nemanja Avramović
Default

HTML:
Kôd:
<input type="checkbox" name="checkbox" value="<?php echo $row['ID'];?>" name="ids[]" />
PHP:
PHP kôd:
$ids $_POST['ids']; //ovo je sad array sa vrednostima obeleženih checkbox-ova 
__________________
Moj portfolio sajtić | wat?
Nemanja Avramović je offline   Odgovorite uz citat
Staro 19. 09. 2013.   #3
slavkan
profesionalac
Professional
 
Datum učlanjenja: 30.08.2010
Poruke: 201
Hvala: 10
640 "Hvala" u 14 poruka
slavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished road
Default

Hvala Nemanja na trudu ali meni treba nesto ovako:

PHP kôd:
<?php
       
while($row $result->fetch_assoc()) 
        {
?>
        <!--Izlistavanje-->
<form action="" method="POST" name="form">
        <tr>
        <td class="align-center"><?php echo $row['ID'];?></td>
        <td><?php echo '<a href="preview.php?idnews='.$row['ID'].'">';?><?php echo $row['naslov_vijesti'];?></a></td>
        <td><?php echo $row['autor_vijesti'];?></td>
        <td><?php echo $row['datum_vijesti'];?></td>
        <td><?php echo $row['tip_vijesti'];?></td>
        <td><?php echo $row['status_vijesti'];?></td>
        <td>
        <input type="checkbox" name="ids[]" value="<?php echo $row['ID'];?>"/>
<a href=""><img src="pencil.gif" width="16" height="16" alt="edit" /></a>

        
        </td>
            </tr>
        
        <?php            
        
}
                 
?>
<div class="table-apply">
                           
         <div>
        <span>Примјени на све одабране вијести:</span> 
        <select class="input-medium" name="selectlist">
        <option value="1">Објави</option>
        <option value="2">Сакриј</option> 
        </select>
        </div>  
<input type="submit" name="submit" value="Pokupi ID"> 
</form>           
</div>
Dakle sad treba da postavim negdje na dnu dugme recimo posle ove select liste i da kupim id-ove cekiranih polja. E sad kako da formiram formu i sta sve treba sa njom da obuhvatim? Nesto ovako:

PHP kôd:
if (isset($_POST['submit']))
{
      if (
$_POST['selectlist'])==1
      
{
             
//Pokupi sve id-ove cekiranih
            //SQL upit 
      
}

slavkan je offline   Odgovorite uz citat
Staro 19. 09. 2013.   #4
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

Pa rekao ti je Nemanja, stavis formu oko cele tabele i kad je submit-ujes posalju se izabrani checkboxovi (samo u njegovom primeru ima jedan name="checkbox" viska).

Znaci, kad imas checkboxes i das im name="nesto[]" onda ce posle submita PHP da dobije niz $_POST['nesto'] (ili $_GET['nesto'] ako je method="get" u formi) koji sadrzi values iz selektovanih chekboxova.

Ako hoces da radis preko ajaxa, reci (to je jednako prosto, nego da te ne zbunjujem sad sa gomilom informacija)
__________________
Leadership is the art of getting people to want to do what you know must be done.
ivanhoe je offline   Odgovorite uz citat
Staro 19. 09. 2013.   #5
slavkan
profesionalac
Professional
 
Datum učlanjenja: 30.08.2010
Poruke: 201
Hvala: 10
640 "Hvala" u 14 poruka
slavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished road
Default

Hvala vam na odgovorima. Pokusacu da ovo uradim pa cu da javim ako uspijem.

Ajax bi mozda bilo najbolje resenje. Ako te ne mrzi i predpostavljam da imas primera nekih takvih skriptica u kompu mozes da podelis ovde.
Predpostavljam da ovi chek box,u slucaju ajax-a, ne bi uopste trebali.
slavkan je offline   Odgovorite uz citat
Staro 19. 09. 2013.   #6
Nemanja Avramović
emperor Selassie
Grand Master
 
Avatar Nemanja Avramović
 
Datum učlanjenja: 20.10.2006
Lokacija: Mladenovac
Poruke: 754
Hvala: 361
576 "Hvala" u 88 poruka
Nemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoroNemanja Avramović će postati "faca" uskoro
Pošaljite ICQ poruku za Nemanja Avramović Pošaljite poruku preko MSN za Nemanja Avramović Pošaljite poruku preko Yahoo za Nemanja Avramović
Default

Uuups... ne videh name="checkbox", odnosno pomešao sam ga sa type="checkbox" :S
__________________
Moj portfolio sajtić | wat?
Nemanja Avramović je offline   Odgovorite uz citat
Staro 20. 09. 2013.   #7
ivanhoe
Ivan Dilber
Sir Write-a-Lot
 
Avatar ivanhoe
 
Datum učlanjenja: 18.10.2005
Lokacija: Bgd
Poruke: 5.320
Hvala: 104
2.344 "Hvala" u 583 poruka
ivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svimaivanhoe je ime poznato svima
Pošaljite poruku preko Skype™ za ivanhoe
Default

jedina razlika kod ajaxa je da se forma ne submituje, nego se podaci posalju jeli ajaxom... checkboxovi ti i dalje trebaju kao jednostavan nacin da user selektuje redove

uz pomoc jQuerija uradis nesto kao u primeru ispod, a na serveru korsitis isti php kao i ranije:
Kôd:
jQuery( function ($) {
	
	var ajaxUrl = 'http://some.com/ajax.php'; //url do tvoje php skripte
	
	// handle onSubmit
	$('#myForm').on('submit', function (e) {
		e.preventDefault(); // zaustavi submit
				
		ajax_submit_selected( $(this) ); // posalji podatke ajaxom, $(this) je isto sto i $('#myForm')
	});
	
	
	function ajax_submit_selected( $form ) {
		var form_data = $form.serialize(); // pokupi podatke iz forme

		$.post(ajaxUrl, form_data, function (response) { // postuj preko ajaxa

			console.log(response); // uradi nesto sa responsom koji salje PHP
		});
	
	}
	
});
Pisem iz glave, mozda ima nekih gresaka...
__________________
Leadership is the art of getting people to want to do what you know must be done.

Poslednja izmena od ivanhoe : 20. 09. 2013. u 02:40.
ivanhoe je offline   Odgovorite uz citat
Staro 25. 09. 2013.   #8
slavkan
profesionalac
Professional
 
Datum učlanjenja: 30.08.2010
Poruke: 201
Hvala: 10
640 "Hvala" u 14 poruka
slavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished roadslavkan is on a distinguished road
Default

Ja sam nesto malo drugacije zamislio da odradim ovaj posao, a to je tako sto cu da imam jednu malu select listu koja ce mi citati ova polja "status" pa tako ce mi prva opcija u listi biti trenutna vrijednost polja status u "bazi" (a postojace samo dvije vrijednosti ""DA" i "NE") pa tako ako je prva opcija "NE" druga ce biti ""DA" i obratno. Da ne bih davio kroz skript ce sve da se vidi:

PHP kôd:
<?php
while($row $result->fetch_assoc()) 
{
?>
<!--Izlistavanje svih vijesti iz baze-->
<form action="" method="GET" name="form">
<tr>
<td class="align-center" id="idvesti"><?php echo $row['ID'];?></td>
<td><?php echo '<a href="preview.php?idnews='.$row['ID'].'">';?>
<?php 
echo $row['naslov_vesti'];?></a></td>
<td><?php echo $row['autor_vesti'];?></td>
<td><?php echo $row['datum_vesti'];?></td>
<td><?php echo $row['tip_vesti'];?></td>
<td>
<select name="" id="status" onchange="editOption(this.value)">
<option value="<?php $row['status_vesti'];?>" >
<?php echo $row['status_vesti'];?>
</option>
<?php
if ($row['status_vesti']=='ДА')
{
echo
'<option value="НЕ" >НЕ</option>';
}else
{
echo
'<option value="ДА" >ДА</option>';
}
?>
</select>
</td>    
<td>
</td>
</tr>                                    
<?php            
}
?>
Evo java script-a:

Kôd:
<script>
function editOption(str)
{
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    var str=(document.form.status.value);
    var idvesti= (document.form.idvesti.value);
    }
  }
xmlhttp.open("GET","editoption.php?q="+str+"&p="+idvesti,true);
xmlhttp.send();
}
</script>
S tim sto ja kroz ovaj javascript moram da pokupim i idvesti koji se Updejtuje pa nisam siguran da sam ovo sintaksno dobro resio.

Ovaj fajl editoption.php je klasika pod uslovom da sam ovo gore dobro formirao:

PHP kôd:
$q = ($_GET['q']);
$p = ($_GET['p']);

$con mysqli_connect('localhost','root','','portal');
if (!
$con)
  {
  die(
'Could not connect: ' mysqli_error($con));
  }

mysqli_select_db($con,"portal");

// Ovde ide $sql za UPDATE mog posalj "status"

$result mysqli_query($con,$sql);

mysqli_close($con); 
Eto za pocetak to pa cemo da prodiskutujemo sta ne valja i sta treba popraviti.
slavkan je offline   Odgovorite uz citat
Odgovori


Alati teme
Način prikaza

Pravila pisanja
Možete ne započinjati nove teme
Možete ne slati odgovore
Možete ne slati priloge
Možete ne izmeniti svoje poruke
vB kôd je Uključen
Smajliji su Uključen
[IMG] kod je Uključen
HTML kôd je Isključen
Pogledajte forum


Vreme je GMT +2. Trenutno vreme je 11:34.


Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.
Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.