麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > CMS > Wordpress > 正文

wordpress中用 iframe 方式插入優酷視頻 兼容移動設備

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

本文我們來講講在wordpress中快速插入優酷視頻mbed方式改為 iframe,這個方式的好處是可以兼容移動設備瀏覽,一舉兩得。

現在的 WordPress 中文版內置了“使用 WordPress 的 Embed 功能快速插入優酷視頻”的功能:只要在寫文章時,獨占一行粘貼優酷視頻地址就可以自動調用次視頻。

例如:我在下一行獨占一行插入 http://v.youku.com/v_show/id_XNTgxNzI3MDcy.html 這個優酷視頻地址,就可以自動調用優酷視頻了。

但是這是用 Embed 的,PC端沒問題,手機瀏覽器因為不支持 Flash 所以是無法顯示和播放視頻的,而現在提供的 iframe 方式插入的視頻就支持手機.

下面說說如何實現:

使用 WordPress 的 Embed 功能快速插入優酷視頻,改為以 iframe 方式調用的方法,有點繞口.

1. 確定所用 WordPress 是中文版(好像其他語言版本也行,如果有錯誤提示就把 wp_embed_unregister_handler( 'youku' ); 刪除即可)

2. 就是把下面的代碼扔進所用主題的 functions.php 里面,注意:代碼要放在 <?php ?> 里面.

  1. /** 
  2.  * 『使用 WordPress 的 Embed 功能快速插入優酷視頻』改為以 iframe 方式調用 
  3.  *  by zwwooooo | zww.me 
  4.  */ 
  5. // 移除原來 WordPress 中文版內置的“使用 WordPress 的 Embed 功能快速插入優酷視頻” 
  6. wp_embed_unregister_handler( 'youku' ); 
  7. // 改用 iframe 方式 
  8. function wp_iframe_handler_youku( $matches$attr$url$rawattr ) { 
  9.     // If the user supplied a fixed width AND height, use it 
  10.     if ( !emptyempty($rawattr['width']) && !emptyempty($rawattr['height']) ) { 
  11.         $width  = (int) $rawattr['width']; 
  12.         $height = (int) $rawattr['height']; 
  13.     } else { 
  14.         list( $width$height ) = wp_expand_dimensions( 480, 400, $attr['width'], $attr['height'] ); //Vevb.com 
  15.     } 
  16.     $iframe = '<iframe width='. esc_attr($width) .' height='. esc_attr($height) .' src="http://player.youku.com/embed/'. esc_attr($matches[1]) .'" frameborder=0 allowfullscreen></iframe>'
  17.     return apply_filters( 'iframe_youku'$iframe$matches$attr$url$ramattr ); 
  18. wp_embed_register_handler( 'youku_iframe''#http://v.youku.com/v_show/id_(.*?).html#i''wp_iframe_handler_youku' ); 

PS:其他視頻網站可以照葫蘆畫瓢改下代碼就行了。

PC端embed方式移動端iframe方式快速插入優酷視頻兩個方法

我共享一下幫一個朋友做主題時寫的這功能的代碼吧,我用以前收藏的移動端判斷函數來實現根據使用環境決定使用 embed 還是 iframe。

懶得具體說明了,直接上代碼吧,里面有注釋:另外這次的代碼我特意修改做了兼容,支持任何語言的 WordPress

代碼實現 PC 端 embed 方式移動端 iframe 方式快速插入優酷視頻功能

1.在 functions.php 插入以下代碼(有些代碼[如判斷是否mobile]收錄自搜索,源自哪里已無從考證——好吧,我忘了,如果你是原創作者請聯系我)

注:凡是加入主題的 functions.php 里面的代碼都要放在 <php ?> 里面.

  1. //判斷是否移動設備 Modify by zwwooooo | zww.me 
  2. function zfunc_is_mobile() { 
  3.     $user_agent = $_SERVER['HTTP_USER_AGENT']; 
  4.     $mobile_agents = Array("240x320","acer","acoon","acs-","abacho","ahong","airness","alcatel","amoi","android","anywhereyougo.com","applewebkit/525","applewebkit/532","asus","audio","au-mic","avantogo","becker","benq","bilbo","bird","blackberry","blazer","bleu","cdm-","compal","coolpad","danger","dbtel","dopod","elaine","eric","etouch","fly ","fly_","fly-","go.web","goodaccess","gradiente","grundig","haier","hedy","hitachi","htc","huawei","hutchison","inno","ipad","ipaq","ipod","jbrowser","kddi","kgt","kwc","lenovo","lg ","lg2","lg3","lg4","lg5","lg7","lg8","lg9","lg-","lge-","lge9","longcos","maemo","mercator","meridian","micromax","midp","mini","mitsu","mmm","mmp","mobi","mot-","moto","nec-","netfront","newgen","nexian","nf-browser","nintendo","nitro","nokia","nook","novarra","obigo","palm","panasonic","pantech","philips","phone","pg-","playstation","pocket","pt-","qc-","qtek","rover","sagem","sama","samu","sanyo","samsung","sch-","scooter","sec-","sendo","sgh-","sharp","siemens","sie-","softbank","sony","spice","sprint","spv","symbian","tablet","talkabout","tcl-","teleca","telit","tianyu","tim-","toshiba","tsm","up.browser","utec","utstar","verykool","virgin","vk-","voda","voxtel","vx","wap","wellco","wig browser","wii","windows ce","wireless","xda","xde","zte"); 
  5.     $is_mobile = false; 
  6.     foreach ($mobile_agents as $device) { 
  7.         if (stristr($user_agent$device)) { 
  8.             $is_mobile = true; 
  9.             break
  10.         } 
  11.     } 
  12.     return $is_mobile
  13.  
  14. //// 如果 WordPress 不是中文版,增加優酷視頻自動插入 Modify by zwwooooo | zww.me 
  15. if (get_bloginfo('language') != 'zh-CN') { 
  16.     function wp_embed_handler_youku( $matches$attr$url$rawattr ) { 
  17.         // If the user supplied a fixed width AND height, use it 
  18.         if ( !emptyempty($rawattr['width']) && !emptyempty($rawattr['height']) ) { 
  19.             $width  = (int) $rawattr['width']; 
  20.             $height = (int) $rawattr['height']; 
  21.         } else { 
  22.             list( $width$height ) = wp_expand_dimensions( 480, 400, $attr['width'], $attr['height'] ); 
  23.         } 
  24.       $embed = sprintf( 
  25.         '<embed src="http://player.youku.com/player.php/sid/%1$s/v.swf" allowFullScreen="true" quality="high" width="'. esc_attr($width) .'" height="'. esc_attr($height) .'" align="middle" allowScriptAccess="always" type="application/x-shockwave-flash"></embed>'
  26.         esc_attr( $matches['video_id'] ) ); 
  27.  
  28.       return apply_filters( 'embed_youku'$embed$matches$attr$url$rawattr ); 
  29.     } 
  30.     wp_embed_register_handler( 'youku',  
  31.       '#https?://v.youku.com/v_show/id_(?<video_id>[a-z0-9_=-]+)#i',  
  32.       'wp_embed_handler_youku' ); 
  33.  
  34. //// 對移動端的視頻使用 iframe 方式插入 by zwwooooo | zww.me 
  35. if( zfunc_is_mobile() ){ 
  36.     //// 如果 WordPress 是中文版,移除原來的 youku 視頻代碼自動插入 
  37.     if (get_bloginfo('language')==='zh-CN'
  38.         wp_embed_unregister_handler( 'youku' ); 
  39.  
  40.     //// 增加 iframe 方式的視頻調用 
  41.     function wp_iframe_handler_youku( $matches$attr$url$rawattr ) { 
  42.         // If the user supplied a fixed width AND height, use it 
  43.         if ( !emptyempty($rawattr['width']) && !emptyempty($rawattr['height']) ) { 
  44.             $width  = (int) $rawattr['width']; 
  45.             $height = (int) $rawattr['height']; 
  46.         } else { 
  47.             list( $width$height ) = wp_expand_dimensions( 480, 400, $attr['width'], $attr['height'] ); 
  48.         } 
  49.         $iframe = '<iframe width='. esc_attr($width) .' height='. esc_attr($height) .' src="http://player.youku.com/embed/'. esc_attr($matches[1]) .'" frameborder=0 allowfullscreen></iframe>'
  50.         return apply_filters( 'iframe_youku'$iframe$matches$attr$url$ramattr ); 
  51.     } 
  52.     wp_embed_register_handler( 'youku_iframe''#http://v.youku.com/v_show/id_(.*?).html#i''wp_iframe_handler_youku' ); 

2.用法:直接把優酷視頻地址粘貼到文章內容里面,注意要獨占一行

繼續玩手機去~最近刷機刷狂了~我喜歡上那些帶 HALO 的 ROM 了……

在評論中,大發提醒 WordPress 已經內置了移動設備判斷函數 wp_is_mobile(),這是 WordPress 3.4 增加的,我沒注意,所以代碼可以精簡成:

  1. //// 如果 WordPress 不是中文版,增加優酷視頻自動插入 Modify by zwwooooo | zww.me 
  2. if (get_bloginfo('language') != 'zh-CN') { 
  3.     function wp_embed_handler_youku( $matches$attr$url$rawattr ) { 
  4.         // If the user supplied a fixed width AND height, use it 
  5.         if ( !emptyempty($rawattr['width']) && !emptyempty($rawattr['height']) ) { 
  6.             $width  = (int) $rawattr['width']; 
  7.             $height = (int) $rawattr['height']; 
  8.         } else { 
  9.             list( $width$height ) = wp_expand_dimensions( 480, 400, $attr['width'], $attr['height'] ); 
  10.         } 
  11.       $embed = sprintf( 
  12.         '<embed src="http://player.youku.com/player.php/sid/%1$s/v.swf" allowFullScreen="true" quality="high" width="'. esc_attr($width) .'" height="'. esc_attr($height) .'" align="middle" allowScriptAccess="always" type="application/x-shockwave-flash"></embed>'
  13.         esc_attr( $matches['video_id'] ) ); 
  14.  
  15.       return apply_filters( 'embed_youku'$embed$matches$attr$url$rawattr ); 
  16.     } 
  17.     wp_embed_register_handler( 'youku',  
  18.       '#https?://v.youku.com/v_show/id_(?<video_id>[a-z0-9_=-]+)#i',  
  19.       'wp_embed_handler_youku' ); 
  20.  
  21. //// 對移動端的視頻使用 iframe 方式插入 by zwwooooo | zww.me 
  22. if( wp_is_mobile() ){ 
  23.     //// 如果 WordPress 是中文版,移除原來的 youku 視頻代碼自動插入 
  24.     if (get_bloginfo('language')==='zh-CN'
  25.         wp_embed_unregister_handler( 'youku' ); 
  26.  
  27.     //// 增加 iframe 方式的視頻調用 
  28.     function wp_iframe_handler_youku( $matches$attr$url$rawattr ) { 
  29.         // If the user supplied a fixed width AND height, use it 
  30.         if ( !emptyempty($rawattr['width']) && !emptyempty($rawattr['height']) ) { 
  31.             $width  = (int) $rawattr['width']; 
  32.             $height = (int) $rawattr['height']; 
  33.         } else { 
  34.             list( $width$height ) = wp_expand_dimensions( 480, 400, $attr['width'], $attr['height'] ); 
  35.         } 
  36.         $iframe = '<iframe width='. esc_attr($width) .' height='. esc_attr($height) .' src="http://player.youku.com/embed/'. esc_attr($matches[1]) .'" frameborder=0 allowfullscreen></iframe>'
  37.         return apply_filters( 'iframe_youku'$iframe$matches$attr$url$ramattr ); 
  38.     } 
  39.     wp_embed_register_handler( 'youku_iframe''#http://v.youku.com/v_show/id_(.*?).html#i''wp_iframe_handler_youku' ); 

OK,WordPress 真是無孔不入啊,牛x到很多人都不用了轉用其他偏門或者小型的博客系統.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产va在线观看 | av影院在线播放 | 美女黄网站免费观看 | 97精品视频在线观看 | 91专区在线观看 | 91精品久久香蕉国产线看观看 | 亚洲黑人在线观看 | 黄色特级视频 | 欧美黄色一级片在线观看 | 国产乱色精品成人免费视频 | 国产精品99久久久久久久女警 | 亚洲成人午夜精品 | 深夜激情视频 | 久久人人爽人人爽人人片av免费 | 免看黄大片aa | 国内精品视频饥渴少妇在线播放 | 美女一级毛片 | 精品一区二区在线观看 | 撅高 自己扒开 调教 | 久久精品视频在线 | 欧美国产91| 一级在线免费观看视频 | 91在线视频播放 | 第一区免费在线观看 | 香蕉黄色网| 欧美成人免费 | 草久免费 | 免费国产成人高清在线看软件 | 美国av片在线观看 | 一级大片久久 | 亚洲精品久久久久www | 国产免费让你躁在线视频 | 精品亚洲视频在线 | 亚洲国产资源 | 韩国精品久久久 | 中文字幕 在线观看 | av在线浏览 | 九一免费国产 | 国产精品视频免费网站 | 精品国产1区2区3区 免费国产 | 素人视频在线观看免费 |