3个设置WordPress内容自动图片添加ALT和TITLE属性的脚本

本文介绍了三种自动为文章图片添加ALT和TITLE属性的方法,以解决编辑时遗漏的问题。通过WordPress函数,可批量将文章标题、分类及网站名称组合为属性内容,提升SEO效果。方法包括正则匹配图片标签、判断属性缺失并自动填充,适用于未设置或属性为空的情况。

WordPress基础教程
阅读时间: 41 分钟
最后更新时间:2025年11月13日

从SEO角度考虑,我们的每篇文章中的图片需要加上ALT和TITLE属性。不过,有些时候我们编辑文章的时候忘记添加属性,那我们有没有办法可以批量自动添加呢?在这篇文章中,我们可以通过可选的办法来通过自动给没有设置ALT和TITLE属性的图片自动添加这篇文章的标题作为2个属性。

1、方法1

function image_alttitle( $imgalttitle ){
global $post;
$category = get_the_category();
$flname=$category[0]->cat_name;
$btitle = get_bloginfo();
$imgtitle = $post->post_title;
$imgUrl = "<imgs[^>]*src=("??)([^" >]*?)\1[^>]*>";
if(preg_match_all("/$imgUrl/siU",$imgalttitle,$matches,PREG_SET_ORDER)){
if( !empty($matches) ){
for ($i=0; $i < count($matches); $i++){
$tag = $url = $matches[$i][0];
$j=$i+1;
$judge = '/title=/';
preg_match($judge,$tag,$match,PREG_OFFSET_CAPTURE);
if( count($match) < 1 )
$altURL = ' alt="'.$imgtitle.' '.$flname.' 第'.$j.'张" title="'.$imgtitle.' '.$flname.' 第'.$j.'张-'.$btitle.'" ';
$url = rtrim($url,'>');
$url .= $altURL.'>';
$imgalttitle = str_replace($tag,$url,$imgalttitle);
}
}
}
return $imgalttitle;
}
add_filter( 'the_content','image_alttitle');

2、方法2

function image_alttitle( $imgalttitle ){
global $post;
$category = get_the_category();
$flname=$category[0]->cat_name;
$btitle = get_bloginfo();
$imgtitle = $post->post_title;
$imgUrl = "<imgs[^>]*src=("??)([^" >]*?)\1[^>]*>";
if(preg_match_all("/$imgUrl/siU",$imgalttitle,$matches,PREG_SET_ORDER)){
if( !empty($matches) ){
for ($i=0; $i < count($matches); $i++){
$tag = $url = $matches[$i][0];
$j=$i+1;
$judge = '/title=/';
preg_match($judge,$tag,$match,PREG_OFFSET_CAPTURE);
if( count($match) < 1 )
$altURL = ' alt="'.$imgtitle.' '.$flname.' 第'.$j.'张" title="'.$imgtitle.' '.$flname.' 第'.$j.'张-'.$btitle.'" ';
$url = rtrim($url,'>');
$url .= $altURL.'>';
$imgalttitle = str_replace($tag,$url,$imgalttitle);
}
}
}
return $imgalttitle;
}
add_filter( 'the_content','image_alttitle');

3、方法3

function wpface_image_alt_title($content) {
  global $post;
  $alt_title = $post->post_title;
  preg_match_all('/<img(.*?)src=('|")(.*?).(bmp|gif|jpeg|jpg|png)('|")(.*?)>/i', $content, $matches);
  if($matches) {
    foreach($matches[0] as $val) {
      $place_content = $val;
      //先把空白 alt 和 title 属性清理掉
      $place_content = str_replace(' alt ', ' ', $place_content);
      $place_content = str_replace(' ', '', $place_content);
      $place_content = str_replace(' title ', ' ', $place_content);
      $place_content = str_replace(' title=""', '', $place_content);
      //如果想覆盖原来的 alt 或 title 属性,就把下面两句的注释取消
      //$place_content = preg_replace('/ alt="(.*?)"/', '', $place_content);
      //$place_content = preg_replace('/ title="(.*?)"/', '', $place_content);
      //判断如果没有 alt 或 title 属性就用文章标题添加
      if(strpos($place_content,'alt=')===false) {
        $place_content = str_replace("/>", "", $place_content).' alt="'.$alt_title.'"/>';
      }
      if(strpos($place_content,'title=')===false) {
        $place_content = str_replace("/>", "", $place_content).' title="'.$alt_title.'"/>';
      }
      //替换 img 标签
      $content = str_replace($val, $place_content, $content);
    }
  }
  return $content;
}
add_filter('the_content','wpface_image_alt_title');

以上方法我们选择一个即可。

这篇文章有用吗?

点击星号为它评分!

平均评分 0 / 5. 投票数: 0

到目前为止还没有投票!成为第一位评论此文章。

在AI里面继续讨论:

曾凤祥

曾凤祥

WordPress技术负责人
小兽WordPress凭借15年的WordPress企业网站开发经验,坚持以“为企业而生的WordPress服务”为宗旨,累计为10万多家客户提供高品质WordPress建站服务,得到了客户的一致好评。我们一直用心对待每一个客户,我们坚信:“善待客户,将会成为终身客户”。小兽WordPress能坚持多年,是因为我们一直诚信。

相关文章

如何让线上业务更上一层楼

还没有WordPress网站

还没有WordPress网站

不管你从事什么行业,WordPress都会为你提供一个专业的主题模板。在WordPress市场上有成千上万的免费主题,适合很多中小企业。

查看所有模板
已经有WordPress网站

已经有WordPress网站

小兽WordPress诚邀你一起学习WordPress,愿与各方携手升级改善您的WordPress网站,一起交流网站加速,网站优化等问题。

马上交个朋友
微信联系
chat 扫码联系
模板建站
挑选模板
网站定制
免费诊断
咨询热线
咨询热线

189-0733-7671

返回顶部