Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wie zieht man Daten aus einer MySQL-Datenbank in ein Stylesheet in einer eigenen Datei/einem eigenen Ordner?

Wenn Sie eine Datenbankvorlage haben, können Sie diese verwenden, um eine .css-Datei zu erstellen, ohne PHP innerhalb der .css-Datei zu verwenden.

Wenn Sie zwei Tabellen haben:

Sie können damit eine CSS-Datei erstellen. Pseudocode:

<?php

    //$db = new PDO('mysql:host=localhist;dbname=cms', 'root', 'root');

    //$query = $db->query("SELECT * FROM `selector`");
    //$query = $query->fetchAll();

    $query = array(
        array('id' => 1, 'selector' => '.thisone'),
        array('id' => 2, 'selector' => '#thatone'),
        array('id' => 3, 'selector' => '.body')
    );

    $probs = array(
        1 => array(
            array('id' => 1, 'selector_id' => 1, 'css_element' => 'border', 'element_value' => '1px solid'),
            array('id' => 2, 'selector_id' => 1, 'css_element' => 'padding', 'element_value' => '10px')
        ),
        2 => array(
            array('id' => 1, 'selector_id' => 2, 'css_element' => 'border', 'element_value' => '1px solid')
        ),
        3 => array(
            array('id' => 1, 'selector_id' => 2, 'css_element' => 'width', 'element_value' => '40px'),
            array('id' => 2, 'selector_id' => 2, 'css_element' => 'height', 'element_value' => '40px')
        )
    );

    $css = '';
    foreach($query as $selector){
        //$properties = $db->query("SELECT * FROM `properties` WHERE `selector_id` = $selector->id");
        //$properties = $properties->fetchAll();

        $properties = $probs[$selector['id']];

        $rules = '';
        foreach($properties as $element){
            $rules .= "\n \t$element[css_element]:$element[element_value];";
        }

        $css .= "$selector[selector]".'{'."$rules \n".'}'."\n\n";
    }

    $fp = fopen('style.css',"w");
    fwrite($fp,$css);
    fclose($fp);

    echo "<pre>";
    echo "$css";
    echo "</pre>";

?>
";?>

Das Ergebnis wird sein:

.thisone{
    border:1px solid;
    padding:10px; 
}

#thatone{
    border:1px solid; 
}

.body{
    width:40px;
    height:40px; 
}

Sie können eine Tabelle mit css_file(id, name) hinzufügen und dann eine css_file_id zur Selektortabelle hinzufügen. Dann kannst du auch mehrere Dateien schreiben.

Sie können auch ein Editor-Formular erstellen, in dem Sie CSS-Regeln/Selektoren/Dateien hinzufügen/entfernen/ändern können.