php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > PHP Developer Forum
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Fragen zu Laravel, YII oder anderen PHP-Frameworks.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 01-04-2005, 16:18
tashideleg
 Newbie
Links : Onlinestatus : tashideleg ist offline
Registriert seit: Apr 2005
Beiträge: 5
tashideleg ist zur Zeit noch ein unbeschriebenes Blatt
Standard Baumstruktur rückwärts auslesen

Hallo, Forumgemeinde,

irgendwie drehen sich die Gedanken im Kreis und ich sehe den Wald vor lauter Bäumen nicht mehr. Ich lege in einem Formular eine Baumstruktur an, aus der später ein Klappmenu werden soll. Hierbei soll nach Klick die jeweilige Unterkategorie ausgeklapt, bzw. eingeklappt werden. Bis zur 2. Ebene funktioniert es ja auch, in dem ich einfach in der kategorie_parent_child tabelle nach den Einträgen suche, wo die parentid übereinstimmt. aber es funktioniert ebend nur über 2 Ebenen. Das Menu kann aber n-fach verschachtelt sein. Habt Ihr da irgendwo einen Lösungsansatz?

Hier der Script zum anlegen.
PHP-Code:
<?php

/*
 ToDo
 
 */
 
include "../../zentrale/head.php";
include 
"../../zentrale/tabellen.php";
include 
"../../zentrale/comein.php";
?>
<link rel="stylesheet" type="text/css" href="../../zentrale/admin.css">

</head>

<body class="show">

Kategorie Einfügen<br>

<?php

$id                
$_POST[id];
$kategorie        $_POST[kategorie];
$kategorieId    $_POST[kategorieId];
$bild            $_POST[bild];

$anlegen        $_POST[anlegen];

if ( isset( 
$anlegen ) ){
    
    
$sqlbefehl "INSERT INTO $MySql_kategorie ";
    
$sqlbefehl .="( beschreibung ) ";
    
$sqlbefehl .="VALUES  ";
    
$sqlbefehl .="( '$kategorie' ) ";

    
mysql_query($sqlbefehl) or die("Error:"mysql_error());
    
    
$kategorie mysql_insert_id();

    
$sqlbefehl "INSERT INTO $MySql_kategorie_parent_child ";
    
$sqlbefehl .="( parent, kategorie ) ";
    
$sqlbefehl .="VALUES  ";
    
$sqlbefehl .="( $kategorieId, $kategorie ) ";

    
mysql_query($sqlbefehl) or die("Error:"mysql_error());

}

    
$aktTiefe 1;
    
    function 
einruecken$tiefe ) {
        
$leerRaum "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;";
        for( 
$i $i $tiefe $i++ ){
            
$einrueckung $einrueckung $leerRaum;
        }
        return 
$einrueckung;
    }
    
    function 
kindSuchen$parent ){
        global 
$sqlhandle$MySql_kategorie$MySql_kategorie_parent_child$aktTiefe
$kategorieTabelle;
        
        
$aktTiefe++;
        
        
$sqlbefehlKategorieChild      "SELECT $MySql_kategorie.* FROM $MySql_kategorie";
        
$sqlbefehlKategorieChild      .= " LEFT JOIN $MySql_kategorie_parent_child ON 
$MySql_kategorie.id = $MySql_kategorie_parent_child.id"
;
        
$sqlbefehlKategorieChild      .= " WHERE $MySql_kategorie_parent_child.parent 
= $parent"
;
        
$sqlbefehlKategorieChild      .= " ORDER BY $MySql_kategorie.beschreibung ASC ";
        
$abfrageKategorieChild        mysql_query($sqlbefehlKategorieChild);

        if( 
mysql_num_rows($abfrageKategorieChild) > ){
            
            for( 
$i $i mysql_num_rows$abfrageKategorieChild ) ; $i++ ){
                
$id             mysql_result$abfrageKategorieChild $i"id");
                
$beschreibung    mysql_result$abfrageKategorieChild $i"beschreibung");
                
                
$tiefe einruecken$aktTiefe );
                print 
"   <tr align='LEFT' valign='TOP'>\n";
                print 
"      <td><input type='radio' name='kategorieId' value='$id'></td>\n";
                print 
"      <td colspan='2'>" $tiefe $beschreibung "</td>\n";
                print 
"   </tr>\n";
                
                
$kategorieTabelle->tabellenLeereZeile);
                
                
kindSuchen$id );
                
            }
        }
        
        
$aktTiefe--;
    }
    
    
$kategorieTabelle = new htmlTabelle"LEFT" "TOP" "" "" ,"false" "Kategorie" 
"Button" 25 "Leerraum" 10 "Text" 400  );
    

    
$kategorieTabelle->tabellenLeereZeile);
    
    print 
"   <form name='Neuanlegen' action='einfuegen.php' method='post' 
enctype='multipart/form-data'>\n"
;
    
    
$kategorieTabelle->tabellenLeereZeile);
    
$kategorieTabelle->tabellenLinie();
    
$kategorieTabelle->tabellenLeereZeile);
    
    print 
"   <tr align='LEFT' valign='TOP'>\n";
    print 
"      <td colspan='3'>Bitte wählen Sie, an welchem Platz die neue Kategorie 
angeordnet werden soll.</td>\n"
;
    print 
"   </tr>\n";
    
    
$kategorieTabelle->tabellenLeereZeile);
    
$kategorieTabelle->tabellenLinie();
    
$kategorieTabelle->tabellenLeereZeile);
    
    print 
"   <tr align='LEFT' valign='TOP'>\n";
    print 
"      <td><input type='radio' name='kategorieId' value='0' checked></td>\n";
    print 
"      <td colspan='2'>Hauptkategorie</td>\n";
    print 
"   </tr>\n";
    
    
$kategorieTabelle->tabellenLeereZeile);
    
    
/*
     Tabelle Kategorie rekursiv auslesen    
     */
     
    
kindSuchen);
    
    
$kategorieTabelle->tabellenLeereZeile);
    
$kategorieTabelle->tabellenLinie();
    
$kategorieTabelle->tabellenLeereZeile);
    
    print 
"   <tr align='LEFT' valign='TOP'>\n";
    print 
"      <td>Kategorie:</td>\n";
    print 
"      <td><img src='../../images/transparent.gif' width='1' height='1'></td>\n";
    print 
"      <td><input type='text' name='kategorie' size='40' maxlength='50' 
class='eingabe_input' value='" 
$artikelnummer  ."'></td>\n";
    print 
"   </tr>\n";
    
    
$kategorieTabelle->tabellenLeereZeile);
    
$kategorieTabelle->tabellenLinie();
    
$kategorieTabelle->tabellenLeereZeile);
    
    print 
"   <tr align='LEFT' valign='TOP'>\n";
    print 
"      <td><img src='../../images/transparent.gif' width='1' height='1'></td>\n";
    print 
"      <td colspan='2'><input type='submit' name='anlegen' value='Neu anlegen' 
class='eingabe_input'></td>\n"
;
    print 
"   </tr>\n";

    print 
"</form>";
    
    
$kategorieTabelle->tabellenFuss();

print 
"</body>\n";
print 
"</html>\n";
?>
Zeilenumbrüche eingefügt

Geändert von tashideleg (01-04-2005 um 16:41 Uhr)
Mit Zitat antworten
freelancermap.de - IT Projektvermittlung für Selbständige und Freiberufler
  #2 (permalink)  
Alt 01-04-2005, 16:21
TobiaZ
  Moderator
Links : Onlinestatus : TobiaZ ist offline
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.421
Blog-Einträge: 1
TobiaZ befindet sich auf einem aufstrebenden Ast
Standard

Welcome on Board,

nicht umsonst haben wir diesen Thread als wichtig markiert und mit "Erst lesen" betitelt. Bitte besonders den bereich mit den Scollbalken beachten!
__________________
ERST LESEN: Unsere Regeln. | Ich hab schon Pferde kotzen sehn!

READ THIS: Strings richtig trennen/verbinden | JOINs, das leidige Thema | Wegwerf E-Mail Adressen

Ich werde keinen privaten 1:1 Support leisten, außer ich biete ihn ausdrücklich an.

Wenn man sich selbst als "Noob" bezeichnet, sollte man die Finger davon lassen.
Wenn man gewillt ist daran etwas zu ändern, lernt man Grundlagen!
Mit Zitat antworten
  #3 (permalink)  
Alt 01-04-2005, 19:20
TobiaZ
  Moderator
Links : Onlinestatus : TobiaZ ist offline
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.421
Blog-Einträge: 1
TobiaZ befindet sich auf einem aufstrebenden Ast
Standard

Sieht besser aus. Danke!

Mein Lösungsansatz wäre rekursion.
__________________
ERST LESEN: Unsere Regeln. | Ich hab schon Pferde kotzen sehn!

READ THIS: Strings richtig trennen/verbinden | JOINs, das leidige Thema | Wegwerf E-Mail Adressen

Ich werde keinen privaten 1:1 Support leisten, außer ich biete ihn ausdrücklich an.

Wenn man sich selbst als "Noob" bezeichnet, sollte man die Finger davon lassen.
Wenn man gewillt ist daran etwas zu ändern, lernt man Grundlagen!
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an


PHP News

PHP Marktplatz-Software
PHP Marktplatz-SoftwareEs hat sich viel getan! Die neue Version 7.5.9 unserer PHP Marktplatz-Software ebiz-trader steht ab sofort zur Verfügung.

28.10.2019 | Berni

Die RIGID-FLEX-Technologie
Die RIGID-FLEX-TechnologieDie sogenannte "Flexible Elektronik" , oftmals auch als "Flexible Schaltungen" bezeichnet, ist eine zeitgemäße Technologie zum Montieren von elektronischen Schaltungen.

06.12.2018 | Berni


 

Aktuelle PHP Scripte

Microweber CMS

Open source, drag and drop website builder

13.01.2020 Berni | Kategorie: HTML5/ EDITOR
PhoneGap Apps mit JS, CSS3 und HTML5 erstellen ansehen PhoneGap Apps mit JS, CSS3 und HTML5 erstellen

PhoneGap, Framework zur Erstellung hybrider Applikationen für mobile Endgeräte.

13.01.2020 Berni | Kategorie: App-Entwicklung
Bo)Tickets

Bo)Tickets bietet Ihnen eine Schnittstelle für Kundenanfragen an. In dem Script definieren Sie Supportbereiche, also zum Beispiel „Technik, Buchhaltung, Support“. Ihre Kunden können dann über ein Formular eine Anfrage abschicken.

31.12.2019 bocombo | Kategorie: PHP/ Ticketsystem
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 06:55 Uhr.