WordPress教程

WordPress自定义字段实现外链缩略图

阿里云

目前使用 WordPress 博客系统建站已经非常多,功能及其强大使用简单,深受广大博主喜欢,但是 WordPress 默认全部支出外链缩微图,其实 WordPress 实现缩略图调用的方法非常多,比如常用的有插件法(WP-Thumbnails),也可以使用特色图片调用法,文章第一张图片缩略调用法等,这里给我大家介绍最简单的一种实现方法:自定义字段实现法。这个功能需要使用 WordPress 函数 add_meta_box,具体介绍 add_meta_box 详解可以到本站搜索下,下面我们介绍两种方法实现 WordPress 自定义字段实现外链缩略图。

实现方法

首先在你的主题目录下的 function.php 文件中(有些是单独的 function_admin.php),新增如下代码:

也想出现在这里?联系我们
创客主机
  1. $new_meta_boxes =
  2. array(
  3.  "description" => array(
  4.  "name" => "imglink",
  5.  "std" => "这里填外链图片地址",
  6.  "title" => "外链缩略图:"),
  7. );
  8. function new_meta_boxes() {
  9.  global $post, $new_meta_boxes;
  10.  foreach($new_meta_boxes as $meta_box) {
  11.  $meta_box_value = get_post_meta($post->ID, $meta_box['name'].'_value', true);
  12.  if($meta_box_value == "")
  13.  $meta_box_value = $meta_box['std'];
  14.  echo'<input type="hidden" name="'.$meta_box['name'].'_noncename" id="'.$meta_box['name'].'_noncename" value="'.wp_create_nonce( plugin_basename(__FILE__) ).'" />';
  15.  // 自定义字段输入框
  16.  echo '<input style="width: 96%;margin: 1% 2%;height: 36px;" type="text" name="'.$meta_box['name'].'_value" value="'.$meta_box_value.'"></input><br />';
  17.  }
  18. }
  19. function create_meta_box() {
  20.  global $theme_name;
  21.  if ( function_exists('add_meta_box') ) {
  22.  add_meta_box( 'new-meta-boxes', '外链缩略图', 'new_meta_boxes', 'post', 'normal', 'high' );
  23.  }
  24. }
  25. function save_postdata( $post_id ) {
  26.  global $post, $new_meta_boxes;
  27.  foreach($new_meta_boxes as $meta_box) {
  28.  if ( !wp_verify_nonce( $_POST[$meta_box['name'].'_noncename'], plugin_basename(__FILE__) )) {
  29.  return $post_id;
  30.  }
  31.  if ( 'page' == $_POST['post_type'] ) {
  32.  if ( !current_user_can( 'edit_page', $post_id ))
  33.  return $post_id;
  34.  }
  35.  else {
  36.  if ( !current_user_can( 'edit_post', $post_id ))
  37.  return $post_id;
  38.  }
  39.  $data = $_POST[$meta_box['name'].'_value'];
  40.  if(get_post_meta($post_id, $meta_box['name'].'_value') == "")
  41.  add_post_meta($post_id, $meta_box['name'].'_value', $data, true);
  42.  elseif($data != get_post_meta($post_id, $meta_box['name'].'_value', true))
  43.  update_post_meta($post_id, $meta_box['name'].'_value', $data);
  44.  elseif($data == "")
  45.  delete_post_meta($post_id, $meta_box['name'].'_value', get_post_meta($post_id, $meta_box['name'].'_value', true));
  46.  }
  47. }
  48. add_action('admin_menu', 'create_meta_box');
  49. add_action('save_post', 'save_postdata');

然后去后台写文章页面看看是否存在外链缩略图面板,如下图:

前端调用

  1. echo "外链缩略图地址:".get_post_meta($post->ID, "thumblink"."_value", true);

其中 thumblink 为外链缩略图的 name,后面的 _value 是自己定义的,如果不喜欢,可以将上面所有 _value 全部删除,注意对比上面的代码。$new_meta_boxes 数组里存放的是自定义面板的信息,如需多个面板,可酌情增加。只需要将缩略图地址输出代码在你主题的相应位置即可。当然这个方法也可以作为其他用途您可以尝试下。

WordPress 自定义字段实现外链缩略图

已有 550 人购买
查看演示升级 VIP立刻购买

收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!