详情
评论
问答
赞助

很多文章页尾会有分享功能,但是本文介绍的是一款比较全的分享,

如题,该功能主要用于生成一份海报页面,具体显示效果如下:

WordPress 添加海报分享功能美化-狐狸库

代码参考自精品资源分享博客,原代码存在一些问题导致添加后不能正常使用,自己对代码做了些简单调整,具体调整内容如下:

  • 核心代码打包至 poster 文件夹,方便调用及维护
  • 更改上传目录为 upload/posterimg (原代码将海报直接上传到媒体库并与文章相关联,并且每次都会生成新的海报,时间长了会导致媒体库臃肿,堆积大量无用文件)
  • 调整前段显示样式(新的样式更好看)
  • 还有一些其他的。。。(我也忘了具体是什么了☹)

使用前请注意:

  • PHP 必须开启 GD 库,绘制海报图片要用到。开启方法看这里>>>PHP 如何开启 GD 库?
  • 必须引入 jQuery ,javascript 中 AJAX 提交到 admin-ajax.php 处理要用到

好了,下面简单说下使用方法。

single.php 文件修改

在single.php 文件中合适位置添加如下代码(前端按钮):

<div class="poster-share-ico"><a class="btn-bigger-cover" data-nonce="<?php echo wp_create_nonce('mi-create-bigger-image-'.$post->ID );?>" data-id="<?php echo $post->ID; ?>" data-action="create-bigger-image" id="bigger-cover" href="javascript:;"><i class="fa fa-paper-plane"></i> <span>生成海报</span></a></div>

footer.php 文件修改

在footer.php 文件中添加如下代码(前端弹窗):

<?php
require_once get_stylesheet_directory() . '/poster/poster-pop.php';?>

functions.php 文件修改

在footer.php 文件中添加如下代码(海报生成):

<?phprequire get_stylesheet_directory() . '/poster/poster.php';?>

生成海报失败的原因

[ghide keyword=”海报分享” key=”FXHB”]

如果海报生成失败了,可能是下面这段 js 代码中路径的问题,默认是没有将 WordPress 安装到子目录的方式,将其修改为你网站的 admin-ajax.php 文件位置应该就可以了。

/** 
  * @name 生成分享海报
  * @author 蝈蝈要安静 | 一个不学无数的伪程序员(修订)
  * @url https://blog.quietguoguo.com 
  * @version 2019年03月19日修订版
  *///提交到wordpress自带的ajax处理$(document).on('click touchstart', '.btn-bigger-cover', function (event) {
    event.preventDefault();
    var bigger_cover = $('.poster-image img'),
        btn_bigger_cover = $('#bigger-cover');
    if (bigger_cover.hasClass('load-poster-img')) {
        $.ajax({
			//url: jsui.ajax_url,
			url: '\/wp-admin\/admin-ajax.php',    // 这地方改成自己的 admin-ajax.php 地址
            type: 'POST',
            dataType: 'json',
            data: btn_bigger_cover.data(),
        }).done(function (data) {
            if (data.s == 200) {
                bigger_cover.attr('src', data.src);
                $('.poster-share-weibo').attr('href', data.share_weibo);
				$('.poster-share-qzone').attr('href', data.share_qzone);
				$('.poster-share-qq').attr('href', data.share_qq);
				$('.poster-share-renren').attr('href', data.share_renren);
                $('.poster-down').attr('href', data.src);
                bigger_cover.removeClass('load-poster-img');
                $('.image-loading').remove();
            } else {
                alert( data.m );
            }
        }).fail(function () {
            alert('Error:网络错误,请稍后再试!');
        })
    }
    $('.poster-share').css({'opacity':'1','visibility':'inherit'});   });//关闭窗口$(document).on('click touchstart','.poster-close',function() {
    $('.poster-share').css({'opacity':'0','visibility':'hidden'}); });

如果按以上步骤设置正确了 ,那么你的主题应该已经实现了海报分享的功能。
如果你是的主题使用了 OptionsFrameWork 框架搭建的后台设置面板,那么下面的步骤将有助于你生成一些后台控制按钮。

options.php 文件修改

将以下代码添加到主题 options.php 文件中去(部分主题可能不叫这名):

//蝈蝈海报$options[] = array(
    'name' => __( '蝈蝈海报', 'QGG' ),
    'type' => 'heading');// 分享海报 $options[] = array(
    'name' => __('海报功能开启', 'QGG'),
    'id' => 'poster_share_open',
    'std' => true,
    'desc' => __('开启', 'QGG'),
    'type' => 'checkbox');$options[] = array(
    'name' => __( '默认头部大图', 'QGG' ),
    'desc' => __( '上传一张显示在封面顶部的大图', 'QGG' ),
    'id' => 'poster_default_img',
    'std' => '',
    'type' => 'upload');$options[] = array(
    'name' => __( '左下角LOGO', 'QGG' ),
    'desc' => __( '上传一张显示在封面底部的LOGO', 'QGG' ),
    'id' => 'poster_logo',
    'std' => '',
    'type' => 'upload');$options[] = array(
    'name' => __( '网站宣传语', 'QGG' ),
    'desc' => __( '显示在LOGO下方的一句宣传语', 'QGG' ),
    'id' => 'poster_desc',
    'std' => '',
    'type' => 'text');$options[] = array(
    'name' => __( '右下角二维码', 'QGG' ),
    'desc' => __( '开启后将再封面图的右下角现在当前文章的二维码', 'QGG' ),
    'id' => 'share_poster_img_qrcode',
    'std' => false,
    'type' => 'checkbox');

single.php 文件调整

将 single.php 文件中的调用代码调整为如下代码:

<!-- 海报分享功能(蝈蝈要安静 2019年03月19日修订版 --><?php if( QGG_options('poster_share_open') ){ ?>
    <div class="poster-share-ico">
        <a class="btn-bigger-cover" data-nonce="<?php echo wp_create_nonce('mi-create-bigger-image-'.$post->ID );?>" data-id="<?php echo $post->ID; ?>" data-action="create-bigger-image" id="bigger-cover" href="javascript:;"><i class="fa fa-paper-plane"></i> <span>生成海报</span></a>
    </div><?php } ?>

poster.php 文件调整

取消 poster.php 文件中如下代码的注释(大概在342行位置):

// 获取海报底部二维码图片//if(QGG_Options('share_poster_img_qrcode')){$qrcode_img = get_template_directory_uri().'/poster/functions/qrcode.php?data='.get_the_permalink($post_id);//}else{//$qrcode_img = NULL;//}

以上就是全部教程,大家可以尝试修改一下,修改前请做好文件备份。

温馨提示:本文最后更新于2022/11/16 14:08:06。若文章内容或图片失效,请留言联系站长反馈!
!
也想出现在这里? 联系我们
创意广告
© 版权声明
THE END
点赞0赞赏 分享

您可以通过搜索或浏览分类列表来找到您期望下载的资源。随后点击资源介绍页右侧的下载链接按钮,依据提示信息进行操作即可。

大部分资源可积分免费下载,为了维持网站的运行小部分资源须付费才能下载。

本站提供的下载资源均为网络搜集,仅供个人学习和交流使用。对于版权问题,请用户自行判断并承担相应责任。

随着时间的推移,维持网站的运行需要支出高昂的服务器和带宽费用。为了能继续坚持免费做下去,如果觉得文章对您有用,希望您能动动发财的小手免费赞助狐狸,给狐狸加油打气!激励狐狸库继续创作下去!谢谢!

在互联网的浩瀚海洋中,我们的网站就像一座明亮的灯塔,为无数用户照亮前行的道路。它承载着知识的传递、梦想的交流,以及大家共同的回忆与期待。然而,运营和维护这样一个网站需要投入大量的心血与资金。

现在,您只需通过支付宝扫码领红包,就能轻松成为我们的赞助人。这不仅是一次简单的支持,更是您与网站共同成长的见证。操作简单,打开支付宝,扫描专属二维码,您的每一份心意都将化作网站发展的动力。

您的赞助,能让网站不断升级,提供更优质的服务,给大家带来更好的体验。让我们携手共进,让这座灯塔绽放更耀眼的光芒,照亮更多人的网络世界 。

下面是免费赞助的方法和流程

  1. 下面图一是本站的支付宝每日领红包二维码,使用支付宝扫描二维码后会自动显示红包金额,有任意小额金额红包。
  2. 点击“去使用”,再扫描第三张图的二维码进行付款即可。
  3. 上面扫到多少红包就输入多少金额,红包会自动抵扣金额,所以不需要额外费用。
  4. 如需赞助自定义金额请到【赞助狐狸】页面进行赞助。
  5. 这个扫码红包是每天都可以领的哦,支持同账号重复,每天花一分钟时间即可免费支持本站!
扫码红包 红包图 扫码支付
评论 共1条

请登录后发表评论

    请登录后查看评论内容