国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > CMS > Wordpress > 正文

詳解WordPress中簡碼格式標簽編寫的基本方法

2024-09-07 00:48:09
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了詳解WordPress中簡碼格式標簽編寫的基本方法,文中講到了添加和移除簡碼等的一些PHP函數的用法,需要的朋友可以參考下。

WordPress 簡碼是一種類似于論壇標簽的東西,格式類似于把尖括號換成中括號的 Html 標簽。簡碼很多人叫做短代碼,但官方的翻譯應該是簡碼,在這里糾正一下。

簡碼的開發的邏輯比較簡單,主要就是添加、刪除和判斷,會在本文全部介紹。

簡碼格式

簡碼的格式非常靈活,可以是有屬性、無屬性、閉合、非閉合等等:

  1. [example] 
  2.  
  3. [example]內容[/example] 
  4.  
  5. [example attr="屬性" attr-hide="1"]內容[/example] 
  6.  
  7. [example "屬性"

添加簡碼

添加簡碼需要使用 add_shortcode() 函數,兩個屬性,第一個為簡碼名,第二個是簡碼的回調函數。

add_shortcode( $tag, $func );

例如添加名為 test 的簡碼,回調 Bing_shortcode_test() 函數:

  1. function Bing_shortcode_test( $attr$content ){ 
  2.   return 'Hello World!'
  3. add_shortcode( 'test''Bing_shortcode_test' ); 

在文章中添加 [test] 就會輸出 “Hello World!”。

從上邊的例子可以看到,簡碼的回調函數需要接收兩個參數。第一個是簡碼所有的屬性,通過數組儲存;第二個是簡碼的內容(閉合簡碼中的內容)。

移除簡碼

remove_shortcode() 函數可以移除一個簡碼,只需要指定簡碼的名稱即可移除。

remove_shortcode( 'test' );

remove_all_shortcodes() 函數用來移除當前添加的所有簡碼。

remove_all_shortcodes();

判斷簡碼

關于判斷簡碼,有兩個函數,shortcode_exists() 函數判斷簡碼是否存在。

  1. remove_all_shortcodes(); 
  2. if( shortcode_exists( 'test' ) ) echo '簡碼 test 存在';//False 
  3. add_shortcode( 'test''Bing_shortcode_test' ); 
  4. if( shortcode_exists( 'test' ) ) echo '簡碼 test 存在';//True 

還有一個 has_shortcode() 函數,判斷字符串中是否出現某某簡碼。

  1. $content = '測試測試測試測試測試測試測試測試'
  2. if( has_shortcode( $content'test' ) ) echo '字符串中有 test 簡碼';//False 
  3. $content = '測試測試測試測[test]測試[/test]試測試測試測試測試'
  4. if( has_shortcode( $content'test' ) ) echo '字符串中有 test 簡碼';//True 

執行簡碼

do_shortcode() 函數用來在字符串中查找簡碼,并在簡碼處調用之前添加的回調函數,把簡碼執行成需要的內容。

WordPress 添加的鉤子:

add_filter( 'the_content', 'do_shortcode', 11 );

例子:

  1. function Bing_shortcode_test( $attr$content ){ 
  2.   return 'Hello World!'
  3. add_shortcode( 'test''Bing_shortcode_test' ); 
  4. $content = '測試測試測試測[test]試測試測試測試測試'
  5. echo do_shortcode( $content );//測試測試測試測Hello World!試測試測試測試測試 

簡碼屬性

簡碼支持各種格式的屬性,接受給簡碼回調函數的第一個參數。如果你要給參數設置默認值,可以使用 shortcode_atts() 函數:

  1. function Bing_shortcode_test( $attr$content ){ 
  2.   extract( shortcode_atts( array
  3.     'url' => 'http://www.bgbk.org'
  4.     'hide' => false, 
  5.     'text' => '點擊隱藏 / 顯示' 
  6.   ), $attr ) ); 
  7.   $hide = $hide ? ' style="display:none;"' : ''
  8.   return '<a href="' . $url . '"' . $hide . '>' . $text . '</a>'
  9. add_shortcode( 'test''Bing_shortcode_test' ); 

只有頁面中使用了簡碼的時候才加載腳本

而在開發的過程中,有時會遇到這種問題:簡碼模塊需要加載 JS 或者 CSS 腳本,而當頁面沒有使用簡碼的時候就會造成資源浪費。

比如下邊的這個 Google 地圖插件:

  1. //添加簡碼 
  2. function Bing_add_google_map( $atts$content ){ 
  3.   //content... 
  4. add_shortcode( 'google_map''Bing_add_google_map'); 
  5.    
  6. //掛載腳本 
  7. function Bing_add_javascript(){ 
  8.   wp_enqueue_script( 'map_scripts' ); 
  9. add_action( 'wp_enqueue_scripts''Bing_add_javascript' ); 

只有在頁面中使用了 [google_map] 簡碼的時候才需要加載腳本,這怎么做到呢?

其實很簡單,只需要在簡碼函數觸發的時候在頁腳掛載腳本即可。

  1. //添加簡碼 
  2. function Bing_add_google_map( $atts$content ){ 
  3.   $GLOBALS['google_map_shortcode'] = true; 
  4.   return '地圖的代碼'
  5. add_shortcode( 'google_map''Bing_add_google_map'); 
  6.    
  7. //掛載腳本 
  8. function Bing_add_javascript(){ 
  9.   global $google_map_shortcode
  10.   if( isset( $google_map_shortcode ) && $google_map_shortcode ) wp_enqueue_script( 'map_scripts' ); 
  11. add_action( 'wp_footer''Bing_add_javascript' ); 

總結:

簡碼是個非常強大的功能,對文章內容是一種很好的擴展,利用好可以讓添加某些東西變的方便快捷。

關于簡碼的函數都在:wp-includes/shortcode.php 文件里,有能力的朋友可以閱讀一下,了解原理。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 满城县| 滦南县| 丰城市| 玉屏| 乌鲁木齐县| 罗平县| 土默特左旗| 天津市| 左云县| 行唐县| 宁远县| 曲沃县| 陆丰市| 古蔺县| 连南| 安泽县| 渭南市| 宜君县| 岳普湖县| 牡丹江市| 伊吾县| 绥宁县| 西丰县| 五家渠市| 江安县| 郓城县| 霍州市| 安庆市| 金门县| 海晏县| 晋江市| 平罗县| 仁怀市| 浮山县| 页游| 米林县| 湘阴县| 安图县| 松溪县| 高州市| 盐山县|