2011-12-19 156 views
5

我在數據庫中定義了幾個變量(十六進制顏色)。我需要通過PHP將這些變量從MySQL傳遞給LESS.js樣式表。可能?將變量傳遞給LESS.js樣式表

如果不是,任何建議的方式來做類似的事情?變亮和變暗是關鍵。

+0

你如何將你的LESS轉換爲CSS? – 2011-12-19 02:05:23

+0

立即設置客戶端。我正在尋找像這樣的東西:href =「styles.less&var = FFF」 – Chords 2011-12-19 02:15:25

+3

那麼,一旦你編譯它,那麼任何變量的概念都會消失。如果你正在轉向服務器端,那肯定是可能的,儘管我並不確定如何。我能想到的最好的事情是讓PHP用這些變量生成一個LESS樣式表,然後將其與其他所有內容一起編譯。 – 2011-12-19 02:17:40

回答

5

我想到的最好的方法是動態生成一個使用PHP(包括你的變量)的LESS文件。

1 \您需要在HTML頁面中包含一個新的樣式表。

<link rel='stylesheet/less' href='css/style.php' /> 

2 \在你style.php包含你的PHP瓦爾如下:

<?php header("Content-type: text/css; charset: UTF-8"); ?> 

@brand_color_1 = <?php echo $brand_color_1; ?>; 
/* Add all other vars do you need. */ 

3 \然後在底部(或之後你少變種聲明)本style.php的添加都需要進口如下:

<?php 
    header("Content-type: text/css; charset: UTF-8"); 

    @brand_color_1 = <?php echo $brand_color_1; ?>; 
    /* Add all other vars do you need. */ 

    @import "style.less"; 
?> 

這會像鐘錶一樣工作。

有一篇文章,你可以read about CSS Variables with PHPChris Coyier寫。


另一個不建議替代被編譯你少的文件在客戶端,你可以手動編譯並通過PHP瓦爾執行以下操作:

<script type="text/javascript"> 
var colors = ''; 
colors += '@brand_color_1: <?php echo $brand_color_1 ?>;' 
colors += '@brand_color_2: <?php echo $brand_color_2 ?>;' 
colors += '@import "style.less"'; 
// Add other imports. 
var parser = new (less.Parser)(); 
parser.parse(colors, function(err, tree) { 
    var css = tree.toCSS(); 
    // Add it to the DOM maybe via jQuery 
}); 
</script> 
+0

「3」存在問題,最後一個'>錯誤! – DUzun 2016-01-14 13:25:34

-1

CSS:

#header { 
    color:black; 
    border:1px solid #dd44dd; 
} 

#header .navigation { 
    font-size:12px; 
} 

#header .navigation a { 
    border-bottom:1px solid green; 
} 

#header .logo { 
    width:300px; 
} 

#header .logo:hover { 
    text-decoration:none; 
} 

LESS:

#header { 
    color:black; 
    border:1px solid #dd44dd; 
    .navigation { 
     font-size:12px; a { 
      border-bottom:1px solid green; 
     } 
    } 
.logo 
+4

Stack Exchange上的所有內容都是[CC-by-SA](http://creativecommons.org/licenses/by-sa/3.0/)。如果您不同意這些條款,那麼Stack Exchange不是您捐款的有效渠道。 – Makoto 2013-05-21 03:08:00