详解WordPress中添加友情链接的方法


Posted in PHP onMay 21, 2016

友情链接对于一个每个独立博客来说可以说是必须的,有不少人选择在侧边栏加入友情链接栏目,但建立一个独立的友情链接页面也是一个不错的选择。用插件可以轻松做到这一点,但喜欢原生的我,能自己动手解决,还是自己动手解决好。折腾了一下,方法就出来了。

普通方法
建立一个友情链接页面的步骤也是比较简单的,先建立一个新的页面模板,用友链函数调用友链,再加上css美化,事情就完成了。

下面说说具体的步骤

1.建立一个新的模板页面
 复制主题中的page.php文件,重命名为links.php。
在页面的顶部加入如下代码

<?php
/*
Template Name: Links
*/
?>

再把类似下面的一段代码

<div class="post-content"><?php the_content(); ?></div>

替换为

<div class="lists"><p class="tips">站点随机排序</p><?php wp_list_bookmarks('orderby=rand&show_images=1'); ?></div>

替换后把links.php放在主题文件夹根目录,然后新建一个页面,在页面模板中选择刚建立的“Links”,保存。
解释一下上面的代码
my_list_bookmarks是WordPress调用友链的函数,orderby是友链的排序方式,这里我写的是rand,也就是随机show_images是控制是否显示友链的图片,布尔型变量,1代表显示变量,0代表不显示,其他可选参数如下:
categorize
布尔型,用于设置连接是否按照各自的分类显示category
字符串型,后面就直接 “=链接分类ID号”,那么就显示这个分类下的链接。如果没有指定的话就显示所有的链接。
category_name
字符串型,如果后面 “=某个链接分类的名称” 那么就会在该链接分类前显示分类的名称,如果这里留空的话则会显示所有链接分类的分类名称(即默认的形式)。
category_before
字符串型,位于链接分类之前的文字或代码。
category_after
字符串型,位于链接分类之后的文字或代码。
class
字符串型,每一个链接的分类都会有一个 “class” 属性(从上面的代码就能看出),默认是:linkcat
category_orderby
字符串型,链接分类的排序方式,按照名词或者ID。
‘name' (默认)
‘id'
category_order
字符串型,链接分类的升降序排列方式:
ASC (默认)
DESC
title_li
字符串型,链接标题的头文字或代码,默认是:Bookmarks,并且它控制连接是否按照列表的方式排列。
title_before 和 title_after
顾名思义,它们就是连接标题头前后的文字或代码,默认是 h2 标签
show_private
布尔型,是否显示私有链接。
include
字符串型,输出指定 ID 的 Blogroll 的分类链接,各个 ID 之间用半角的 “,” 分开。默认显示所有的 Blogroll 分类。
exclude
字符串型,将指定 ID 的 Blogroll 分类链接从整个链接列表中排除,各个 ID 之间用半角的 “,” 分开。默认是什么都不排除。
orderby
字符串型,Blogroll 的排列方式(默认是根据名称排序,除非将这个值留空),即根据我们在 WP 后台链接设置界面下的那些参数来进行排序:
(1)'id'
(2)‘url'
(3)‘name'
(4)‘target'
(5)‘description'
(6)‘owner'
(7)‘rating'
(8)‘updated'
(9)‘rel' ? 按设定的关系排列
(10)‘notes'
(11)‘rss'
(12)‘length' ? 连接名称的长度设定
(13)‘rand' ? 随机排列显示
order
字符串型,设置升降序的排列方式
ASC (默认)
DESC
limit
整型,设置输出链接条数的最大值。默认值是”-1″,输出全部。
between
字符串型,每个连接、图片和描述之间的文字或代码,默认是 “n” 换行。
show_description
布尔型,是否允许显示每个链接的描述。
show_rating
布尔型,是否允许显示链接的等级。
show_updated
布尔型,是否允许显示最近更新后的时间戳。
hide_invisible
布尔型,是否显示所有的链接,甚至是被管理员设为不可见的链接,默认允许显示。

2.添加css美化,以下是个人的css,供大家参考

.lists {padding: 5px; margin: 25px auto auto 0;}
.linkcat {font-size: 12px; font-weight: bolder; padding: 5px; margin-bottom: 15px; list-style: none; clear:both}
.lists li h2 {font-size:14px; margin-bottom: 15px; color: #99CC33; }
.listcat ul {margin-left: 20px;}
.linkcat ul li {float: left; margin-bottom: 20px; margin-left: 20px; padding: 4px 0 4px 6px; width: 150px; border: 1px solid #d9d9d9;}
.linkcat ul li a {color: #a4a4a4; text-decoration: none;}
.linkcat ul li a img {margin-right: 3px;}
.linkcat ul li a:visited {color: #a4a4a4;}
.tips {font-size: 14px; margin-bottom: 18px; margin-left: 5px;}

使用jQuery
具体实现步骤分两步:
1.加载jQuery库,可以直接调用google jQuery库

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
2.加载jQuery功能代码,注意jQuery闭合
$(".linkpage a").each(function(e){
$(this).prepend("<img src=http://www.google.com/s2/favicons?domain="+this.href.replace(/^(http:\/\/[^\/]+).*$/, '$1').replace( 'http://', '' )+">");
});
这段jQuery的意思是遍历所有class为linkpage下所有的a标签,然后对该a标签添加img,其中是“.linkpage”需根据自己的模板更改。
PHP 相关文章推荐
一个简单的MySQL数据浏览器
Oct 09 PHP
php 数学运算验证码实现代码
Oct 11 PHP
php基础学习之变量的使用
Jun 09 PHP
php selectradio和checkbox默认选择的实现方法详解
Jun 29 PHP
PHP curl 获取响应的状态码的方法
Jan 13 PHP
使用PHP强制下载PDF文件示例
Jan 17 PHP
避免Smarty与CSS语法冲突的方法
Mar 02 PHP
WordPress中编写自定义存储字段的相关PHP函数解析
Dec 25 PHP
PHP Static延迟静态绑定用法分析
Mar 16 PHP
Laravel中的chunk组块结果集处理与注意问题
Aug 15 PHP
php实现通过stomp协议连接ActiveMQ操作示例
Feb 23 PHP
PHP实现简单的计算器
Aug 28 PHP
PHP框架Laravel插件Pagination实现自定义分页
Apr 22 #PHP
屏蔽PHP默认设置中的Notice警告的方法
May 20 #PHP
PHP获取网站中各文章的第一张图片的代码示例
May 20 #PHP
今天你说520了吗?不仅有php表白书还有java表白神器
May 20 #PHP
程序员的表白神器“520”大声喊出来
May 20 #PHP
PHP性能优化大全(php.ini)
May 20 #PHP
自定义min版smarty模板引擎MinSmarty.class.php文件及用法
May 20 #PHP
You might like
MYSQL数据库初学者使用指南
2006/11/16 PHP
mysql 搜索之简单应用
2007/04/27 PHP
PHP 断点续传实例详解
2017/11/11 PHP
Laravel第三方包报class not found的解决方法
2019/10/13 PHP
Z-Blog中用到的js代码
2007/03/15 Javascript
JavaScript浏览器选项卡效果
2010/08/25 Javascript
jQuery探测位置的提示弹窗(toolTip box)详细解析
2013/11/14 Javascript
日常收藏的jquery技巧
2015/12/02 Javascript
详解AngularJS验证、过滤器、指令
2017/01/04 Javascript
JS实现汉字与Unicode码相互转换的方法详解
2017/04/28 Javascript
React入门教程之Hello World以及环境搭建详解
2017/07/11 Javascript
在页面中引入js的两种方法(推荐)
2017/08/29 Javascript
解决js ajax同步请求造成浏览器假死的问题
2018/01/18 Javascript
详解webpack loader和plugin编写
2018/10/12 Javascript
浅谈vue后台管理系统权限控制思考与实践
2018/12/19 Javascript
vue h5移动端禁止缩放代码
2019/10/28 Javascript
[00:55]深扒TI7聊天轮盘语音出处3
2017/05/11 DOTA
在Django的模型中添加自定义方法的示例
2015/07/21 Python
修复 Django migration 时遇到的问题解决
2018/06/14 Python
python读取raw binary图片并提取统计信息的实例
2020/01/09 Python
Python猜数字算法题详解
2020/03/01 Python
HTML5中在title标题标签里设置小图标的方法
2020/06/23 HTML / CSS
Ann Taylor官方网站:美国最大的女性产品制造商之一
2016/09/14 全球购物
Meli Melo官网:名媛们钟爱的英国奢侈手包品牌
2017/04/17 全球购物
仓库主管的岗位职责
2013/12/04 职场文书
kfc实习自我鉴定
2013/12/14 职场文书
学生会主席事迹材料
2014/01/28 职场文书
《自选商场》教学反思
2014/02/14 职场文书
课前三分钟演讲稿
2014/04/24 职场文书
2014年创先争优活动总结
2014/05/04 职场文书
小学语文教学经验交流材料
2014/06/02 职场文书
国际贸易系求职信
2014/08/09 职场文书
民主生活会批评与自我批评总结
2014/10/17 职场文书
导游欢迎词范文
2015/01/23 职场文书
教师工作决心书
2015/02/04 职场文书
2015年度环卫处工作总结
2015/07/24 职场文书