前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >『教程』首页及文章页滚动广告栏

『教程』首页及文章页滚动广告栏

作者头像
云计算小黑
发布2022-12-28 21:09:15
1K0
发布2022-12-28 21:09:15
举报
文章被收录于专栏:小黑博客

前言

因为之前在很多网站上都能看到广告,虽然但是,这对很多博主来说也是一笔额外的收入,我一直是入不敷出!

然后我看到了执念博客的首页广告栏,虽然曝光确实大,但是用户体验极其不好,因为要翻很多广告才能翻到文章,就像这样:

所以我就想到了滚动广告,一个广告的位置,能够显示多条广告

成果展示

首页

文章页

教程开始

灵感及相关代码来自于Joe主题的首页轮播图

一、添加后台

打开 functions.php 添加以下代码

代码语言:javascript
复制
$JADPost = new Typecho_Widget_Helper_Form_Element_Textarea(
        'JADPost',
        NULL,
        NULL,
        '文章页顶部广告',
        '介绍:用于设置文章页顶部广告 

         格式:广告图片 || 跳转链接 (中间使用两个竖杠分隔)

         注意:如果您只想显示图片不想跳转,可填写:广告图片 || javascript:void(0)  

         其他:一行一个,一行代表一个轮播广告图'
    );
    $JADPost->setAttribute('class', 'joe_content joe_post');
    $form->addInput($JADPost);

这是文章页的代码,因为首页广告主题自带了

二、添加滚动广告栏

首页 因为首页已经有广告位了,所以直接替换就行了

将主题 index.php 的以下代码直接替换为新代码

代码位置

新代码

代码语言:javascript
复制
<div class="joe_index__ad">
                        <?php
                            $index_ad = [];
                            $index_ad_text = $this->options->JIndex_Ad;
                            if ($index_ad_text) {
                            $index_ad_arr = explode("\r\n", $index_ad_text);
                            if (count($index_ad_arr) > 0) {
                                for ($i = 0; $i < count($index_ad_arr); $i++) {
                                    $img = explode("||", $index_ad_arr[$i])[0];
                                    $url = explode("||", $index_ad_arr[$i])[1];
                                    $index_ad[] = array("img" => trim($img), "url" => trim($url));
                                };
                            }
                            }
                        ?>
                        <?php if (sizeof($index_ad) > 0) : ?>
                            <div class="swiper-container">
                                <div class="swiper-wrapper">
                                    <?php foreach ($index_ad as $item) : ?>
                                    <div class="swiper-slide">
                                        <a class="item" href="<?php echo $item['url'] ?>" target="_blank" rel="noopener noreferrer nofollow">
                                            <img width="100%" class="image lazyload" src="<?php _getLazyload() ?>" data-src="<?php echo $item['img'] ?>" ?>" />
                                        </a>
                                    </div>
                                    <?php endforeach; ?>
                                </div>
                                <div class="swiper-pagination"></div>
                                <span class="icon">广告</span>
                            </div>
                        <?php endif; ?>
                    </div>

文章页 文章页直接在主题的 post.php 文件内合适的地方加入以下代码

代码位置

代码

代码语言:javascript
复制
<div class="joe_index__ad">
                        <?php
                            $index_ad = [];
                            $index_ad_text = $this->options->JIndex_Ad;
                            if ($index_ad_text) {
                            $index_ad_arr = explode("\r\n", $index_ad_text);
                            if (count($index_ad_arr) > 0) {
                                for ($i = 0; $i < count($index_ad_arr); $i++) {
                                    $img = explode("||", $index_ad_arr[$i])[0];
                                    $url = explode("||", $index_ad_arr[$i])[1];
                                    $index_ad[] = array("img" => trim($img), "url" => trim($url));
                                };
                            }
                            }
                        ?>
                        <?php if (sizeof($index_ad) > 0) : ?>
                            <div class="swiper-container">
                                <div class="swiper-wrapper">
                                    <?php foreach ($index_ad as $item) : ?>
                                    <div class="swiper-slide">
                                        <a class="item" href="<?php echo $item['url'] ?>" target="_blank" rel="noopener noreferrer nofollow">
                                            <img width="100%" class="image lazyload" src="<?php _getLazyload() ?>" data-src="<?php echo $item['img'] ?>" ?>" />
                                        </a>
                                    </div>
                                    <?php endforeach; ?>
                                </div>
                                <div class="swiper-pagination"></div>
                                <span class="icon">广告</span>
                            </div>
                        <?php endif; ?>
                    </div>

三、修改广告栏样式

首页 直接在 Joe/assets/css 打开 joe.index.min.css 然后在最后添加以下代码

代码语言:javascript
复制
.joe_index__ad .swiper-container{height: 180px!important;border-radius: var(--radius-inner);}.joe_index__ad .swiper-container .icon{position:absolute;z-index:1;top:10px;right:10px;font-size:12px;background:rgba(0,0,0,0.25);padding:2px 5px;border-radius:2px;color:#ebebeb;pointer-events:none}@media (max-width: 768px){.joe_index__ad .swiper-container{height: 120px!important}.joe_index__ad .swiper-container .image{height: 120px;object-fit: cover;border-radius: var(--radius-inner);}}

文章页 直接在 Joe/assets/css 打开 joe.post.min.css 然后在最后添加以下代码

代码语言:javascript
复制
.joe_post__ad .swiper-container{height: 180px!important;margin-top:15px;border-radius: var(--radius-inner);}.joe_post__ad .swiper-container .icon{position:absolute;z-index:1;top:10px;right:10px;font-size:12px;background:rgba(0,0,0,0.25);padding:2px 5px;border-radius:2px;color:#ebebeb;pointer-events:none}@media (max-width: 768px){.joe_post__ad .swiper-container{height: 120px!important}.joe_post__ad .swiper-container .image{height: 120px;object-fit: cover;border-radius: var(--radius-inner);}}

四、添加滚动效果

首页

首页因为引入了滚动效果,所有不需要设置,会直接调用首页轮播图的滚动效果

但是会根据首页轮播图的滚动方式滚动,效果不太好,暂时没想到比较好的解决方法

文章页 首先在主题的 post.php 文件内 标签内加入以下代码

代码语言:javascript
复制
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/swiper@5.4.5/css/swiper.min.css" />
<script src="https://cdn.jsdelivr.net/npm/swiper@5.4.5/js/swiper.min.js"></script>

然后再在 Joe/assets/js 打开 joe.post_page.min.js 然后在最后添加以下代码

代码语言:javascript
复制
if(0!==$(".joe_post__ad .swiper-container").length){let e="vertical";new Swiper(".swiper-container",{keyboard:!1,direction:e,loop:!0,autoplay:!0,mousewheel:!0,pagination:{el:".swiper-pagination"},})}

添加位置

教程结束

大功告成,快刷新你的网站看看效果吧!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、添加后台
  • 二、添加滚动广告栏
  • 三、修改广告栏样式
  • 四、添加滚动效果
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档