首頁 後端開發 php教程 如何將巢狀的PHP陣列轉換為CSS規則? (程式碼範例)

如何將巢狀的PHP陣列轉換為CSS規則? (程式碼範例)

Mar 18, 2019 pm 03:55 PM
php數組

應用程式的許多方面都可以自動化,例如我們可以使用某些PHP程式碼(如使用陣列)來產生樣式表。那麼如何實現?以下這篇文章就來帶大家了解如何將巢狀的PHP陣列轉換為CSS規則,並以字串的形式顯示,希望對大家有幫助。

如何將巢狀的PHP陣列轉換為CSS規則? (程式碼範例)

下面我們就來看看將巢狀的關聯陣列轉換為CSS字元的方法。

1、編寫關聯陣列轉換為css字串的函數

#要在PHP中將陣列轉換為CSS字串(在SASS或LESS的情況下使用規則或簡單變數),我們將使用以下函數:

<?php
/**
 * @param array $rules
 *   CSS规则的数组形式为:
 *   array(&#39;selector&#39;=>array(&#39;property&#39; => &#39;value&#39;)). 
 *   还支持选择器
 *   嵌套示例:
 *   array(&#39;selector&#39; => array(&#39;selector&#39;=>array(&#39;property&#39; => &#39;value&#39;))).
 *
 * @return 字符串一个CSS规则字符串。它不包含在<style>标签中。
 */
function css_array_to_css($rules, $indent = 0) {
    $css = &#39;&#39;;
    $prefix = str_repeat(&#39;  &#39;, $indent);
    foreach ($rules as $key => $value) {
        if (is_array($value)) {
            $selector = $key;
            $properties = $value;
            $css .= $prefix . "$selector {\n";
            $css .= $prefix . css_array_to_css($properties, $indent + 1);
            $css .= $prefix . "}\n";
        } else {
            $property = $key;
            $css .= $prefix . "$property: $value;\n";
        }
    }
    return $css;
}
//调用css_array_to_css()函数转换
//code
?>
登入後複製

說明:該函數基本上期望作為第一個參數包含CSS的規則或簡單屬性的數組,其中不是數組的每個key =>value;都將表示為key : value;,如果鍵的值是數組,則規則為css將被引入。

2、使用函數

正如上述函數說明中所提到的,它從具有指定規則的數組中返回一個CSS字符串。只要數組的結構有效,函數就可以正常用於純CSS規則,媒體查詢,SASS和LESS。例如:

● 轉換為CSS:

在css_array_to_css()函數後新增以下程式碼:

$stylesheet = array(
    "body" => array(
        "margin" => "0",
        "font-size" => "1rem",
        "font-weight" => 400,
        "line-height" => 1.5,
        "color" => "#212529",
        "text-align" => "left",
        "background-color" => "#fff"
    ),
    ".form-control" => array(
        "display" => "block",
        "width" => "100%!important",
        "font-size" => "1em",
        "background-color" => "#fff",
        "border-radius" => ".25rem"
    )
);
echo(css_array_to_css($stylesheet));
登入後複製

上一個程式碼段將輸出以下CSS規則:

body {
  margin: 0;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  text-align: left;
  background-color: #fff;
}
.form-control {
  display: block;
  width: 100%!important;
  font-size: 1em;
  background-color: #fff;
  border-radius: .25rem;
}
登入後複製

● 轉換為SASS / SCSS:

由於遞歸實現,將能夠在規則中嵌套多個規則,這允許我們為SASS產生有效的語法:

$sass = array(
    "nav" => array(
        "ul" => array(
            "margin" => 0,
            "padding" => 0,
            "list-style" => "none"
        ),
        "li" => array(
            "display" => "inline-block"
        ),
        "a" => array(
            "display" => "block",
            "padding" => "6px 12px",
            "text-decoration" => "none"
        )
    )
);
echo css_array_to_css($sass);
登入後複製

上一個程式碼片段將輸出以下SASS程式碼:

nav {
  ul {
      margin: 0;
      padding: 0;
      list-style: none;
  }
  li {
      display: inline-block;
  }
  a {
      display: block;
      padding: 6px 12px;
      text-decoration: none;
  }
}
登入後複製

● 轉換為LESS:

與SASS的工作方式相同,我們也可以使用LESS來寫複雜的規則:

$less = array(
    "@nice-blue" => "#5B83AD",
    "@light-blue" => "@nice-blue + #111",
    "#header" => array(
        "color" => "@light-blue"
    ),
    ".component" => array(
        "width" => "300px",
        "@media (min-width: 768px)" => array(
            "width" => "600px",
            "@media (min-resolution: 192dpi)" => array(
                "background-image" => "url(/img/retina2x.png)"
            )
        ),
        "@media (min-width: 1280px)" => array(
            "width" => "800px"
        )
    )
);
echo css_array_to_css($less);
登入後複製

上一個程式碼片段將輸出以下LESS程式碼:

@nice-blue: #5B83AD;
@light-blue: @nice-blue + #111;
#header {
  color: @light-blue;
}
.component {
  width: 300px;
  @media (min-width: 768px) {
    width: 600px;
    @media (min-resolution: 192dpi) {
          background-image: url(/img/retina2x.png);
    }
  }
  @media (min-width: 1280px) {
      width: 800px;
  }
}
登入後複製

相關影片教學推薦:《PHP教學

以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。更多精彩內容大家可以追蹤php中文網相關教學欄位! ! !

以上是如何將巢狀的PHP陣列轉換為CSS規則? (程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1422
52
Laravel 教程
1316
25
PHP教程
1266
29
C# 教程
1239
24
如何使用PHP數組實現圖表和統計圖的產生和顯示 如何使用PHP數組實現圖表和統計圖的產生和顯示 Jul 15, 2023 pm 12:24 PM

如何使用PHP數組實現圖表和統計圖的生成和顯示PHP是一種廣泛使用的伺服器端腳本語言,具有強大的資料處理和圖形生成能力。在Web開發中,經常需要展示資料的圖表和統計圖,透過PHP數組,我們可以輕鬆實現這些功能。本文將介紹如何使用PHP數組產生和顯示圖表和統計圖,並提供相關的程式碼範例。引入必要的庫文件和樣式表在開始之前,我們需要在PHP文件中引入一些必要的庫文

如何使用PHP陣列產生動態投影片和圖片展示 如何使用PHP陣列產生動態投影片和圖片展示 Jul 15, 2023 pm 01:17 PM

如何使用PHP陣列產生動態投影片和圖片展示投影片和圖片展示是網頁設計中常見的功能,常被應用於輪播圖、圖庫展示等場景。而PHP作為一種流行的伺服器端腳本語言,具備處理資料和產生動態HTML頁面的能力,非常適合用於產生動態投影片和圖片展示。本文將介紹如何使用PHP陣列產生動態投影片和圖片展示,並給出對應的程式碼範例。準備圖片資料首先,我們需要準備一組圖片的路徑數據

如何使用PHP陣列實現使用者登入和權限管理的功能 如何使用PHP陣列實現使用者登入和權限管理的功能 Jul 15, 2023 pm 08:55 PM

如何使用PHP陣列實現使用者登入和權限管理的功能在開發網站時,使用者登入和權限管理是非常重要的功能之一。透過使用者登錄,我們可以驗證使用者身分並保護網站的安全性。而權限管理則能夠控制使用者在網站中的操作權限,確保使用者只能存取他們被授權的功能。在本文中,我們將介紹如何使用PHP陣列來實現使用者登入和權限管理的功能。我們將使用一個簡單的範例來演示這個過程。首先,我們需要創建

php數組二維怎麼轉一維數組 php數組二維怎麼轉一維數組 Aug 03, 2023 am 11:14 AM

php數組二維轉一維數組的方法:1、使用循環遍歷,使用循環遍歷二維數組,將每個元素添加到一維數組中;2、使用“array_merge”函數,可以將多個數字組合併為一個數組,將二維數組當作參數傳遞給“array_merge”函數,將其轉換為一維數組;3、使用“array_reduce”函數,可以將數組中的所有值通過一個回調函數來處理,並最後返回一個結果。

php怎麼判斷陣列有幾個 php怎麼判斷陣列有幾個 Aug 04, 2023 pm 05:40 PM

php判斷陣列有幾個的方法:1、使用count()函數,適用於所有類型的陣列。但要注意的是,如果傳入的參數不是數組,count()函數會傳回0;2、使用sizeof()函數,更多用於保持與其他程式語言的相容性;3、自訂函數,透過使用循環遍歷數組,每遍歷一次,計數器加1,最終得到數組的長度。自訂函數可以根據實際需求進行修改和擴展,更加靈活。

PHP數組的效能最佳化技巧探究 PHP數組的效能最佳化技巧探究 Mar 13, 2024 pm 03:03 PM

PHP數組是一種非常常見的資料結構,在開發過程中常會用到。然而,隨著資料量的增加,數組的效能可能會成為一個問題。本文將探討一些PHP數組的效能最佳化技巧,並提供具體的程式碼範例。 1.使用適當的資料結構在PHP中,除了普通數組外,還有一些其他資料結構,如SplFixedArray、SplDoublyLinkedList等,它們在特定情況下可能比普通數組效能更好

php數組鍵值對是什麼 php數組鍵值對是什麼 Aug 03, 2023 pm 02:20 PM

php數組鍵值對是一種資料結構,由一個鍵和一個對應的值組成,鍵是數組元素的標識符,而值是與鍵相關聯的資料。允許我們以鍵為標識來儲存和存取數據,透過使用鍵值對,可以更方便地操作和管理數組中的元素,使得程式開發更加靈活和高效。

php數組求平均值的函數有哪些 php數組求平均值的函數有哪些 Jul 17, 2023 pm 04:03 PM

php數組求平均值的函數有:1、array_sum(),用於計算數組中所有值的總和,為了計算平均值,可以將數組中的所有值相加,然後除以數組元素的數量;2 、array_reduce(),用於迭代數組並將每個值與一個初始值進行計算;3、array_mean(),用於返回數組的平均值,先計算數組的總和,併計算數組元素的個數,將總和除以數組元素的個數,即得到平均值。

See all articles