排行榜 统计
  • 文章总数:1142 篇
  • 评论总数:5 条
  • 分类总数:8 个
  • 最后更新:13小时前

wp/wordpress给分类加封面图,前端可以调取!

本文阅读 1 分钟
首页 程序人生 正文


本文转自:https://blog.51cto.com/u_15791907/5676887

做资源主题的时候总想给分类加一个封面,然后在首页或分类页调取相应的封面,这样算是自定义分类封面功能吧,废话不多说,七娃将整理好的代码奉上:



wp/wordpress给分类加封面图,前端可以调取!_php




wp/wordpress给分类加封面图,前端可以调取!_jquery_02


1.function.php添加:

当然你也可以将下面代码复制到一个php文件里面,然后在function.php里面“include(TEMPLATEPATH.'/admin/cat.php');”这个文件也是可以的

<?php
if (!defined('q_PLUGIN_URL'))
define('q_PLUGIN_URL', untrailingslashit(plugins_url('', __FILE__)));

define('q_IMAGE_PLACEHOLDER', get_template_directory_uri()."/images/ad.png");

add_action('admin_init', 'initTaxonomy');
function initTaxonomy() {
$taxonomies = get_taxonomies();
if (is_array($taxonomies)) {
foreach ($taxonomies as $taxonomy) {
add_action($taxonomy.'_add_form_fields', 'addTaxonomyField');
add_action($taxonomy.'_edit_form_fields', 'editTaxonomyField');
add_filter('manage_edit-' . $taxonomy . '_columns', 'addTaxonomyColumns');
add_filter('manage_' . $taxonomy . '_custom_column', 'addTaxonomyColumn', 10, 3);
}
}
}

function addTaxonomyColumns($columns) {
$column = array();
$column['thumbnail'] = "图像";
return array_merge($column, $columns);
}

function addTaxonomyColumn($columns, $column, $id) {
if ($column == 'thumbnail')
$columns = '<span><img src="'.getTaxonomyImageUrl($id, NULL, TRUE) .'" class="wp-post-image" /></span>';

return $columns;
}

function addTaxonomyStyle() {
echo '<style type="text/css" media="screen">
th.column-thumb {width:60px;}
.form-field img.taxonomy-image {display:block;max-width:100%;border:1px solid #eee;max-height:300px;}
.column-thumb span {width:48px;height:48px;border:1px solid #eee;display:inline-block;}
.inline-edit-row fieldset .thumb img,.column-thumbnail img {display: block; width:100%;height:80px;}
</style>';
}

// add image field in add form
function addTaxonomyField() {
if (get_bloginfo('version') >= 3.5)
wp_enqueue_media();
else {
wp_enqueue_style('thickbox');
wp_enqueue_script('thickbox');
}
echo '<div class="form-field">
<label for="taxonomy_image">' . __('图像', 'qui') . '</label>
<input type="text" name="taxonomy_image" id="taxonomy_image" value="" />
<br/>
<button class="q_upload_image_button button">' . __('上传/添加图像', 'qui') . '</button>
</div>'.q_script();
}

/**
* @param $taxonomy
*
*/
function editTaxonomyField($taxonomy) {
if (get_bloginfo('version') >= 3.5)
wp_enqueue_media();
else {
wp_enqueue_style('thickbox');
wp_enqueue_script('thickbox');
}

if (getTaxonomyImageUrl($taxonomy->term_id, NULL, TRUE ) == q_IMAGE_PLACEHOLDER)
$image_text = "";
else
$image_text = getTaxonomyImageUrl( $taxonomy->term_id, NULL, TRUE );

$icon = get_term_meta($taxonomy->term_id, "taxonomyIcon", true);
echo '<tr class="form-field">
<th scope="row" valign="top"><label for="taxonomy_image">' . __('图像', 'qui') . '</label></th>
<td><img class="taxonomy-image" src="' . getTaxonomyImageUrl( $taxonomy->term_id, NULL, TRUE ) . '"/><br/><input type="text" name="taxonomy_image" id="taxonomy_image" value="'.$image_text.'" /><br />
<button class="q_upload_image_button button">' . __('上传/添加图像', 'qui') . '</button>
<button class="q_remove_image_button button">' . __('删除图像', 'qui') . '</button>
</td>
</tr>'.q_script();
}
// upload using wordpress upload
function q_script() {
return '<script type="text/javascript">
jQuery(document).ready(function($) {
var wordpress_ver = "'.get_bloginfo("version").'", upload_button;
$(".q_upload_image_button").click(function(event) {
upload_button = $(this);
var frame;
if (wordpress_ver >= "3.5") {
event.preventDefault();
if (frame) {
frame.open();
return;
}
frame = wp.media();
frame.on( "select", function() {
// Grab the selected attachment.
var attachment = frame.state().get("selection").first();
frame.close();
if (upload_button.parent().prev().children().hasClass("tax_list")) {
upload_button.parent().prev().children().val(attachment.attributes.url);
upload_button.parent().prev().prev().children().attr("src", attachment.attributes.url);
}
else
$("#taxonomy_image").val(attachment.attributes.url);
});
frame.open();
}
else {
tb_show("", "media-upload.php?type=image&TB_iframe=true");
return false;
}
});

$(".q_remove_image_button").click(function() {
$("#taxonomy_image").val("");
$(this).parent().siblings(".title").children("img").attr("src","' . q_IMAGE_PLACEHOLDER . '");
$(".inline-edit-col :input[name=\'taxonomy_image\']").val("");
return false;
});

if (wordpress_ver < "3.5") {
window.send_to_editor = function(html) {
imgurl = $("img",html).attr("src");
if (upload_button.parent().prev().children().hasClass("tax_list")) {
upload_button.parent().prev().children().val(imgurl);
upload_button.parent().prev().prev().children().attr("src", imgurl);
}
else
$("#taxonomy_image").val(imgurl);
tb_remove();
}
}

$(".editinline").live("click", function(){
var tax_id = $(this).parents("tr").attr("id").substr(4);
var thumb = $("#tag-"+tax_id+" .thumb img").attr("src");
if (thumb != "' . q_IMAGE_PLACEHOLDER . '") {
$(".inline-edit-col :input[name=\'taxonomy_image\']").val(thumb);
} else {
$(".inline-edit-col :input[name=\'taxonomy_image\']").val("");
}
$(".inline-edit-col .title img").attr("src",thumb);
return false;
});
});
</script>';
}
// save our taxonomy image while edit or save term
add_action('edit_term','setTaxonomyImageUrl');
add_action('create_term','setTaxonomyImageUrl');

function setTaxonomyImageUrl($term_id) {
if(isset($_POST['taxonomy_image']))
update_term_meta($term_id, "taxonomyImage", $_POST['taxonomy_image']);
if(isset($_POST['taxonomy-icon']))
update_term_meta($term_id, "taxonomyIcon", $_POST['taxonomy-icon']);
}

// get attachment ID by image url
// getAttachmentIdByUrl
function getAttachmentIdByUrl($image_src) {
global $wpdb;
$query = "SELECT ID FROM {$wpdb->posts} WHERE guid = '$image_src'";
$id = $wpdb->get_var($query);
return (!empty($id)) ? $id : NULL;
}

// get taxonomy image url for the given term_id (Place holder image by default)
function getTaxonomyImageUrl($term_id = NULL, $size = NULL, $return_placeholder = FALSE) {
if (!$term_id) {
if (is_category())
$term_id = get_query_var('cat');
elseif (is_tax()) {
$current_term = get_term_by('slug', get_query_var('term'), get_query_var('taxonomy'));
$term_id = $current_term->term_id;
}
}
$taxonomy_image_url = get_term_meta($term_id, "taxonomyImage", true);
if(!empty($taxonomy_image_url)) {
$attachment_id = getAttachmentIdByUrl($taxonomy_image_url);
if(!empty($attachment_id)) {
if (empty($size))
$size = 'full';
$taxonomy_image_url = wp_get_attachment_image_src($attachment_id, $size);
$taxonomy_image_url = $taxonomy_image_url[0];
}
}

if ($return_placeholder)
return ($taxonomy_image_url != '') ? $taxonomy_image_url : q_IMAGE_PLACEHOLDER;
else
return $taxonomy_image_url;
}

function quickEditInTaxonomy($column, $screen, $name) {

if ($column == 'thumbnail')
echo '<fieldset>
<div class="thumb inline-edit-col">
<label>
<span class="title">图像</span>
<span class="input-text-wrap"><input type="text" name="taxonomy_image" class="tax_list" /></span>
<span class="input-text-wrap">
<button class="q_upload_image_button button">' . __('上传/添加图像', 'qui') . '</button>
<button class="q_remove_image_button button">' . __('删除图像', 'qui') . '</button>
</span>
</label>
</div>
</fieldset>';
}

add_action('admin_head', 'addTaxonomyStyle');

// style the image in category list
if (strpos( $_SERVER['SCRIPT_NAME'], 'edit-tags.php') > 0 ) {
add_action('quick_edit_custom_box', 'quickEditInTaxonomy', 10, 3);
}

2.前端调用:getTaxonomyImageUrl,参数$term_id或$cat指定对应分类即可!

<img src="<?php echo getTaxonomyImageUrl($term_id=4); ?>" />





本文来自投稿,不代表本站立场,如若转载,请注明出处:https://typecho.firshare.cn/archives/3105.html
免责声明:文章内容不代表本站立场,本站不对其内容的真实性、完整性、准确性给予任何担保、暗示和承诺,仅供读者参考,文章版权归原作者所有。避免网络欺诈,本站不倡导任何交易行为。如您私自与本站转载自公开互联网中的资讯内容中提及到的个人或平台产生交易,则需自行承担后果。本站在注明来源的前提下推荐原文至此,仅作为优良公众、公开信息分享阅读,不进行商业发布、发表及从事营利性活动。如本文内容影响到您的合法权益(内容、图片等),请及时联系本站,我们会及时删除处理。
-- 展开阅读全文 --
如何给wordpress 分类增加图片
« 上一篇 03-12
输入身份证号码查询名下手机号-帮查机主身份信息平台
下一篇 » 03-15