亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

shortcode短代碼功能怎么在WordPress項目中使用

發布時間:2021-01-14 15:16:22 來源:億速云 閱讀:205 作者:Leah 欄目:開發技術

shortcode短代碼功能怎么在WordPress項目中使用?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

一.shortcode 簡介

shortcode 可以讓開發者通過以函數的形式創建宏內容來生成內容,或許這個概念看上去有點模糊,但實際上它是一個很簡單而實用的功能,只要會編寫基本的 PHP 函數,即可使用 shortcode ,下文會以實際的例子來說明 shortcode 的使用方法。

二.shortcode 形式
shortcode 支持封閉標簽和自閉(自動封閉)標簽,并且支持在標簽內使用參數,至于 shortcode 具體是何種形式,這就決定于開發者怎樣編寫這個 shortcode 了。

[myshortcode]Some Content[/myshortcode] // 封閉標簽
[myshortcode] // 自閉標簽
[myshortcode title="example"] // 帶有一個參數的自閉標簽
[myshortcode]<p><a href="#"><span>內容</span></a></p>[/myshortcode] // 標簽內可以填寫文本或 HTML
[myshortcode]Content [myshortcodesecond] more content[/myshortcodesecond] // 也可以嵌套使用標簽

三.shortcode 例子
在使用 shortcode 前,首先必須在主題的 functions.php 文件中定義 shortcode ,例如:

function myshortcode_function($atts, $content = null){ // $atts 代表了 shortcode 的各個參數,$content 為標簽內的內容
 
 extract(shortcode_atts(array( // 使用 extract 函數解析標簽內的參數
 "title" => '標題' // 給參數賦默認值,下面直接調用 $ 加上參數名輸出參數值
 ), $atts));
 // 返回內容
 return '<div class="myshortcode">
    <h4>'. $title .'</h4>
    <p>
     '. $content .'
    </p>
   </div>';
}
 
add_shortcode("msc", "myshortcode_function"); // 注冊該 shortcode,以后使用 [msc] 標簽調用該 shortcode

把上面的代碼添加到 functions.php 中,一個簡單的 shortcode 便創建好了,我們可以通過 [msc][/msc]標簽調用該 shortcode ,如:

[msc title="歡迎"]這是獨立博客 Kayo's Melody ,歡迎來到本博客[/msc]

在文章或頁面內容中輸入上面的調用,可以在相應的位置輸出一段歡迎語句,在 style.css 中定義相應的 CSS ,即可為短代碼賦予樣式。

Kayo 簡略的介紹了 WordPress 的短代碼(shortcode) 功能,主要是介紹了 shortcode 的主要概念和使用方法。在本文中, Kayo 將會更加詳細的介紹一下 shortcode 中較為重要的 API ,希望有助于各位開發較為復雜的 shortcode 。

四.函數 add_shortcode

該函數用于注冊一個 shortcode ,它有兩個參數:短代碼名與 shortcode 處理函數名,引用上文的例子:

function myshortcode_function($atts, $content = null){ // $atts 代表了 shortcode 的各個參數,$content 為標簽內的內容
 
 extract(shortcode_atts(array( // 使用 extract 函數解析標簽內的參數
 "title" => '標題' // 給參數賦默認值,下面直接調用 $ 加上參數名輸出參數值
 ), $atts));
 // 返回內容
 return '<div class="myshortcode">
    <h4>'. $title .'</h4>
    <p>
     '. $content .'
    </p>
   </div>';
}
 
add_shortcode("msc", "myshortcode_function"); // 注冊該 shortcode,以后使用 [msc] 標簽調用該 shortcode

msc 即為短代碼名,以后在寫文章或頁面時可以直接使用 [msc][/msc] 標簽調用該短代碼,而 "myshortcode_function" 即為例子中的短代碼處理函數的名稱。下面重點分析短代碼處理函數。

五.短代碼處理函數

shortcode 處理函數是一個 shortcode 的核心, shortcode 處理函數類似于 Flickr(WordPress 過濾器),它們都接受特定參數,并返回一定的結果。 shortcode 處理器接受兩個參數, $attr 和 $content , $attr 代表 shortcode 的各個屬性參數,從本質上來說是一個關聯數組,而 $content 代表 shortcode 標簽中的內容。

如上面的例子,若在文章內作出調用,輸出一段歡迎語句:

[msc title="歡迎"]這是獨立博客 Kayo's Melody ,歡迎來到本博客[/msc]
當文章顯示時, WordPress 會注冊所有的 shortcode ,如上面的 [msc] ,若 shortcode 中有屬性參數和內容, WordPress 會把它們分離出來并解析,然后傳遞給該 shortcode 的短代碼處理函數,處理后以處理函數輸出的結果代替短代碼原本的內容顯示在文章內。

這時屬性參數會并解析會關聯數組并傳遞給 $attr ,如上面的例子中 $attr 的值為如下的一個關聯數組:

array( 'title' => '歡迎')

在輸出結果時,可以直接使用 $參數名 的形式進行輸出,如例子中的情況即以 $title 輸出該屬性值。

六.shortcode_atts

shortcode_atts 是一個很實用的函數,它可以為你需要的屬性參數設置默認值,并且刪除一些不需要的參數。

shortcode_atts() 包含兩個參數 $defaults_array 與 $atts , $attr 即為屬性參數集合, $defaults_array 是代表需要設置的屬性默認值,舉個例子:

$result = shortcode_atts( array(
 'title' => '新標題',
 'description' => '描述內容'
), $atts );
$attr 依然為

array( 'title' => '歡迎')

這時 $result 的結果為

array( 'title' => '新標題', 'description' => '描述標題')

'title' 由于在 $defaults_array 有不同的值,因此以這個新的值為準更新了 'title' ,同時也增加了 'description' 這個值。值得注意的是, shortcode_atts() 會過濾 $defaults_array 中沒有的屬性,假如 $attr 中還有一個 'ohter' 的屬性,那么 $result 的結果仍然是上面的結果,因為 $defaults_array 中并沒有 'other' 這個屬性。當然,這里說的值只是屬性的默認值,真正輸出的值還是 shortcode 調用時填寫的值。

七.進一步解析屬性與設置屬性默認值

extract() 函數用于進一步解析屬性并設置屬性默認值,其中一個功能是把各屬性參數值賦予給一個形如 "$參數名" 的變量保存起來(如例子中的 $title ),方便調用,使用該函數配合 shortcode_atts() 就可以很安全的輸出結果。這點的具體使用可以參見本文第一點“一.函數 add_shortcode”的例子。

另外,屬性名中的大寫字母在傳遞給處理函數前會先轉化為小寫字母,因此建議在編寫屬性名時直接使用小寫字母。

看完上述內容,你們掌握shortcode短代碼功能怎么在WordPress項目中使用的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安康市| 永寿县| 贵州省| 衡阳县| 新宾| 大新县| 苍梧县| 新兴县| 巩义市| 棋牌| 贞丰县| 汝城县| 峨边| 三明市| 府谷县| 浙江省| 左贡县| 大丰市| 韶山市| 桃江县| 北川| 历史| 黔西| 安泽县| 苏尼特左旗| 石林| 阳东县| 新兴县| 德阳市| 文昌市| 舒城县| 黄山市| 岱山县| 吉木萨尔县| 宁安市| 科技| 赤壁市| 即墨市| 滦平县| 志丹县| 靖宇县|