WordPress中用于获取及自定义头像图片的PHP脚本详解
<p><strong>get_avatar()(获取头像)</strong><br>
get_avatar() 函数用来获取置顶邮箱或者用户的头像代码,在评论列表中非常常用。</p>
<p>
这个函数提供一个 get_avatar 过滤器,用来过滤头像的 Html 代码(img 标签)。</p>
<p>
如果在后台 “设置” 的 “讨论” 里关闭 “显示头像选项” 则返回 False.</p>
<p>
用法</p>
<div>
<div>
<div id="highlighter_450982">
<div>
</div>
<div>
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
1</div>
</td>
</tr></tbody></table>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
</div>
</td>
<td>
<div>
<div>
<code>get_avatar( </code><code>$id_or_email</code><code>, </code><code>$size</code><code>, </code><code>$default</code><code>, </code><code>$alt</code> <code>);</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div id="codetool">
<div>
<textarea></textarea>
</div>
</div>
</div>
<p>
参数</p>
<p>
$id_or_email</p>
<p>
(整数 | 字符串 | 对象)(必须)用户的 ID;邮箱;评论或者用户的对象。如果在循环中可以使用 get_the_author_meta( 'ID' ) 函数调用当前文章的作者。</p>
<p>
默认值:None</p>
<p>
$size</p>
<p>
(整数)(可选)头像的尺寸,最大为 512,单位为像素(px)。</p>
<p>
默认值:96<br>
get_avatar()(获取头像)<br>
$default</p>
<p>
(字符串)(可选)如果没有头像返回的图片,默认为 “神秘人”,可以是图片 URL.</p>
<p>
默认值:空字符串(神秘人)</p>
<p>
$alt</p>
<p>
(字符串)(可选)头像 img 标签的 alt 属性内容。</p>
<p>
默认值:False</p>
<p>
返回值</p>
<p>
(字符串 | 布尔)返回一个头像的 img 标签,如果在后台 “设置” 的 “讨论” 里关闭 “显示头像选项” 则返回 False.</p>
<p>
例子</p>
<p>
评论列表:</p>
<div>
<div>
<div id="highlighter_99663">
<div>
</div>
<div>
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
1</div>
</td>
</tr></tbody></table>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
</div>
</td>
<td>
<div>
<div>
<code><?php </code><code>echo</code> <code>get_avatar( </code><code>$GLOBALS</code><code>[</code><code>'comment'</code><code>] ); ?></code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div id="codetool">
<div>
<textarea></textarea>
</div>
</div>
</div>
<p>
循环,获取当前文章作者头像:</p>
<div>
<div>
<div id="highlighter_395769">
<div>
</div>
<div>
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
1</div>
</td>
</tr></tbody></table>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
</div>
</td>
<td>
<div>
<div>
<code><?php </code><code>echo</code> <code>get_avatar( get_the_author_meta( </code><code>'ID'</code> <code>), 32 ); ?></code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div id="codetool">
<div>
<textarea></textarea>
</div>
</div>
</div>
<p>
自定义邮箱:</p>
<div>
<div>
<div id="highlighter_254763">
<div>
</div>
<div>
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
1</div>
</td>
</tr></tbody></table>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
</div>
</td>
<td>
<div>
<div>
<code><?php </code><code>echo</code> <code>get_avatar( </code><code>'email@example.com'</code><code>, 32, </code><code>''</code><code>, </code><code>'自定义邮箱'</code> <code>); ?></code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div id="codetool">
<div>
<textarea></textarea>
</div>
</div>
</div>
<p>
<br><strong>自定义头像图片的 alt 标签</strong><br>WordPress 默认使用的是 Gravatar 头像,通过 get_avatar() 函数调用,一般用来在调用评论的时候使用。</p>
<p>
利用 get_avatar() 函数的第四个属性 $alt 可以设置返回代码的 alt 标签,但是大多数人在使用的时候都不会去设置,也就变成了空白。</p>
<p>
搜索引擎的爬虫是无法读取图片上到底是什么内容的,只能靠它的 alt 标签,没有了 alt 标签的图片,对 SEO 是非常不好的。</p>
<p>
如果想要给所有的头像都统一加上一个 alt 标签,可以把下边的代码放到主题的 functions.php(了解更多) 文件。</p>
<div>
<div>
<div id="highlighter_743519">
<div>
</div>
<div>
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
1</div>
</td>
</tr></tbody></table>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
</div>
<div>
2</div>
<div>
3</div>
<div>
4</div>
<div>
5</div>
<div>
6</div>
<div>
7</div>
<div>
8</div>
<div>
9</div>
<div>
10</div>
<div>
11</div>
<div>
12</div>
<div>
13</div>
<div>
14</div>
</td>
<td>
<div>
<div>
<code>/**</code>
</div>
<div>
<code> </code><code>*WordPress 自定义头像图片的 alt 标签</code>
</div>
<div>
<code> </code><code>*根据不同的人生成不同的 alt 标签</code>
</div>
<div>
<code> </code><code>*</code><code>http://www.endskin.com/avatar-alt/</code>
</div>
<div>
<code>*/</code>
</div>
<div>
<code>function</code> <code>Bing_avatar_alt( </code><code>$avatar</code> <code>){</code>
</div>
<div>
<code> </code><code>$alt</code> <code>= </code><code>'Gravatar 头像'</code><code>;</code><code>//alt 标签的内容</code>
</div>
<div>
<code> </code><code>$before</code> <code>= </code><code>strpos</code><code>( </code><code>$avatar</code><code>, </code><code>"alt='"</code> <code>);</code>
</div>
<div>
<code> </code><code>$after</code> <code>= </code><code>strpos</code><code>( </code><code>$avatar</code><code>, </code><code>"'"</code><code>, </code><code>$before</code> <code>);</code>
</div>
<div>
<code> </code><code>if</code><code>( </code><code>$before</code> <code>=== false || </code><code>$after</code> <code>=== false ) </code><code>return</code> <code>$avatar</code><code>;</code>
</div>
<div>
<code> </code><code>$alt</code> <code>= esc_attr( </code><code>$alt</code> <code>);</code>
</div>
<div>
<code> </code><code>return</code> <code>substr</code><code>( </code><code>$avatar</code><code>, 0, </code><code>$before</code> <code>) . </code><code>"alt='$alt"</code> <code>. </code><code>substr</code><code>( </code><code>$avatar</code><code>, </code><code>$after</code> <code>+ </code><code>strlen</code><code>( </code><code>"'"</code> <code>) );</code>
</div>
<div>
<code>}</code>
</div>
<div>
<code>add_filter( </code><code>'get_avatar'</code><code>, </code><code>'Bing_avatar_alt'</code> <code>);</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div id="codetool">
<div>
<textarea></textarea>
</div>
</div>
</div>
<p>
这样就行了,注意修改代码里的 $alt 变量为你要修改成的 alt 标签内容。</p>
<p>
根据不同的人生成不同的 alt 标签</p>
<p>
如果要根据不同的人放置不同的 alt 标签可以用下边的例子代码:</p>
<div>
<div>
<div id="highlighter_959192">
<div>
</div>
<div>
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
1</div>
</td>
</tr></tbody></table>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
</div>
<div>
2</div>
<div>
3</div>
<div>
4</div>
<div>
5</div>
<div>
6</div>
<div>
7</div>
<div>
8</div>
<div>
9</div>
<div>
10</div>
<div>
11</div>
<div>
12</div>
<div>
13</div>
<div>
14</div>
<div>
15</div>
<div>
16</div>
<div>
17</div>
</td>
<td>
<div>
<div>
<code>/**</code>
</div>
<div>
<code> </code><code>*WordPress 自定义头像图片的 alt 标签</code>
</div>
<div>
<code> </code><code>*</code><code>http://www.endskin.com/avatar-alt/</code>
</div>
<div>
<code>*/</code>
</div>
<div>
<code>function</code> <code>Bing_avatar_alt( </code><code>$avatar</code><code>, </code><code>$id_or_email</code> <code>){</code>
</div>
<div>
<code> </code><code>if</code><code>( </code><code>$id_or_email</code> <code>== </code><code>'bingoblog@163.com'</code> <code>|| </code><code>$id_or_email</code> <code>=== 1 ){</code>
</div>
<div>
<code> </code><code>$alt</code> <code>= </code><code>'博主 Gravatar 头像'</code><code>;</code><code>//博主的 alt 标签内容</code>
</div>
<div>
<code> </code><code>}</code><code>else</code><code>{</code>
</div>
<div>
<code> </code><code>$alt</code> <code>= </code><code>'Gravatar 头像'</code><code>;</code><code>//普通访客的 alt 标签内容</code>
</div>
<div>
<code> </code><code>}</code>
</div>
<div>
<code> </code><code>$before</code> <code>= </code><code>strpos</code><code>( </code><code>$avatar</code><code>, </code><code>"alt='"</code> <code>);</code>
</div>
<div>
<code> </code><code>$after</code> <code>= </code><code>strpos</code><code>( </code><code>$avatar</code><code>, </code><code>"'"</code><code>, </code><code>$before</code> <code>);</code>
</div>
<div>
<code> </code><code>if</code><code>( </code><code>$before</code> <code>=== false || </code><code>$after</code> <code>=== false ) </code><code>return</code> <code>$avatar</code><code>;</code>
</div>
<div>
<code> </code><code>$alt</code> <code>= esc_attr( </code><code>$alt</code> <code>);</code>
</div>
<div>
<code> </code><code>return</code> <code>substr</code><code>( </code><code>$avatar</code><code>, 0, </code><code>$before</code> <code>) . </code><code>"alt='$alt"</code> <code>. </code><code>substr</code><code>( </code><code>$avatar</code><code>, </code><code>$after</code> <code>+ </code><code>strlen</code><code>( </code><code>"'"</code> <code>) );</code>
</div>
<div>
<code>}</code>
</div>
<div>
<code>add_filter( </code><code>'get_avatar'</code><code>, </code><code>'Bing_avatar_alt'</code><code>, 10, 2 );</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div id="codetool">
<div>
<textarea></textarea>
</div>
</div>
</div>
<p>
如果已经设置 alt 标签则不替换</p>
<p>
如果你需要在已经设置 alt 标签的内容(get_avatar() 函数的 $alt 属性)则不替换的时候可以用下边的代码:</p>
<div>
<div>
<div id="highlighter_392742">
<div>
</div>
<div>
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
1</div>
</td>
</tr></tbody></table>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td>
<div>
</div>
<div>
2</div>
<div>
3</div>
<div>
4</div>
<div>
5</div>
<div>
6</div>
<div>
7</div>
<div>
8</div>
<div>
9</div>
<div>
10</div>
<div>
11</div>
<div>
12</div>
<div>
13</div>
<div>
14</div>
<div>
15</div>
</td>
<td>
<div>
<div>
<code>/**</code>
</div>
<div>
<code> </code><code>*WordPress 自定义头像图片的 alt 标签</code>
</div>
<div>
<code> </code><code>*如果已经设置 alt 标签则不替换</code>
</div>
<div>
<code> </code><code>*</code><code>http://www.endskin.com/avatar-alt/</code>
</div>
<div>
<code>*/</code>
</div>
<div>
<code>function</code> <code>Bing_avatar_alt( </code><code>$avatar</code><code>, </code><code>$id_or_email</code><code>, </code><code>$size</code><code>, </code><code>$default</code><code>, </code><code>$alt</code> <code>){</code>
</div>
<div>
<code> </code><code>if</code><code>( !</code><code>empty</code><code>( </code><code>$alt</code> <code>) ) </code><code>return</code> <code>$avatar</code><code>;</code>
</div>
<div>
<code> </code><code>$alt</code> <code>= </code><code>'Gravatar 头像'</code><code>;</code><code>//alt 标签的内容</code>
</div>
<div>
<code> </code><code>$before</code> <code>= </code><code>strpos</code><code>( </code><code>$avatar</code><code>, </code><code>"alt='"</code> <code>);</code>
</div>
<div>
<code> </code><code>$after</code> <code>= </code><code>strpos</code><code>( </code><code>$avatar</code><code>, </code><code>"'"</code><code>, </code><code>$before</code> <code>);</code>
</div>
<div>
<code> </code><code>if</code><code>( </code><code>$before</code> <code>=== false || </code><code>$after</code> <code>=== false ) </code><code>return</code> <code>$avatar</code><code>;</code>
</div>
<div>
<code> </code><code>$alt</code> <code>= esc_attr( </code><code>$alt</code> <code>);</code>
</div>
<div>
<code> </code><code>return</code> <code>substr</code><code>( </code><code>$avatar</code><code>, 0, </code><code>$before</code> <code>) . </code><code>"alt='$alt"</code> <code>. </code><code>substr</code><code>( </code><code>$avatar</code><code>, </code><code>$after</code> <code>+ </code><code>strlen</code><code>( </code><code>"'"</code> <code>) );</code>
</div>
<div>
<code>}</code>
</div>
<div>
<code>add_filter( </code><code>'get_avatar'</code><code>, </code><code>'Bing_avatar_alt'</code><code>, 10, 5 );</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div id="codetool">
<div>
<textarea></textarea>
</div>
</div>
</div>
<p>
</p>
頁:
[1]