继续本教程:http://wp.tutsplus.com/tutorials/create-a-responsive-slider-plugin-with-flexslider/
我正在尝试添加一些元框,以便为每张幻灯片添加更多内容。这里以“链接”元框开头是我的slider-img-type.php代码:
<?php
define('CPT_NAME', "Slider Images");
define('CPT_SINGLE', "Slider Image");
define('CPT_TYPE', "slider-image");
define('CPT_THUMB_SIZE', 500);
add_theme_support('post-thumbnails', array('slider-image'));
function efs_register() {
$args = array(
'label' => __(CPT_NAME),
'singular_label' => __(CPT_SINGLE),
'public' => true,
'show_ui' => true,
'capability_type' => 'post',
'hierarchical' => false,
'rewrite' => true,
'supports' => array('title', 'editor', 'thumbnail')
);
register_post_type(CPT_TYPE , $args );
set_post_thumbnail_size(CPT_THUMB_SIZE);
}
add_action('init', 'efs_register');
add_action("admin_init", "efs_meta_box");
function efs_meta_box(){
add_meta_box("projInfo-meta", "EFS Options", "efs_meta_options", "efs", "side", "low");
}
function efs_meta_options(){
global $post;
if ( defined('DOING_AUTOSAVE') && DOING_AUTOSAVE ) return $post_id;
$custom = get_post_custom($post->ID);
$link = $custom["projLink"][0];
?>
<label>Link:</label><input name="projLink" value="<?php echo $link; ?>" />
<?php
}
add_action('save_post', 'save_efs_link');
function save_efs_link(){
global $post;
if ( defined('DOING_AUTOSAVE') && DOING_AUTOSAVE ){
return $post_id;
}else{
update_post_meta($post->ID, "projLink", $_POST["projLink"]);
}
}
?>
也许我错过了一些明显的东西,但是当我尝试添加新的Slider Image帖子类型时,我无法显示链接输入字段。
非常感谢任何帮助。
谢谢, 詹姆斯
基于rmlumley代码的修订代码:
function efs_meta_options(){
global $post;
$custom = get_post_custom($post->ID);
$link = $custom["projLink"][0];
?>
<label>Link:</label><input name="projLink" value="<?php echo $link; ?>" />
<?php
}
add_action('save_post', 'save_efs_link');
function save_efes_link($post_ID = 0){
$post_ID = (int) $post_ID;
$post_type = get_post_type( $post_ID );
$post_status = get_post_status( $post_ID );
if ($post_type) {
update_post_meta($post->ID, "projLink", $_POST["projLink"]);
}
return $post_ID;
} ?>
我刚刚注意到另一个解决方案发布到教程的评论中,但这似乎对我没有用处:
http://wp.tutsplus.com/tutorials/create-a-responsive-slider-plugin-with-flexslider/#comment-14080
我认为这些评论删除了显示锚标记的正确代码:
$slider.='<li><a href='.$slide_link.'>'.$img.'</a></li>';
我尝试在'value'输入字段中添加一个带有网址的自定义字段'link_slide_to',但幻灯片仍然在锚点悬停时没有显示网址。