最近访客

WordPress站长在发表文章时,往往不注意给图片添加说明(ALT),导致大量文章中的图像缺少 ALT属性,不利于SEO。网上有很多自动给文章图片添加ALT属性的教程,这里转个国外的方法供参考。

将title标签作为WordPress文章图片的ALT-狐狸库
wordpress

只需将下面的代码添加到当前主题函数模板functions.php中即可。

function callback($buffer) {
 	/* modify buffer here, and then return the updated code*/
 	$title=\'\';
 	$res = preg_match(\'/<title>(.*?)</title>/\', $buffer, $title_matches);
  	if ($res) {
 		/*Clean up title: remove EOL\'s and excessive whitespace.*/
 		$title = preg_replace(\'/s+/\', \' \', $title_matches[1]);
 		$title = trim($title);
 	}
  	preg_match_all(\'/<img (.*?)/>/\', $buffer, $images);
 	if(!is_null($images)) {
 		foreach($images[1] as $index => $value) {
 			preg_match(\'/alt=\"(.*?)\"/\', $value, $img);
 			preg_match(\'/alt=\'(.*?)\'/\', $value, $img2);
 			if(!is_null($images)) {
 				if((!isset($img[1]) || $img[1] == \'\') || (!isset($img2[1]) || $img2[1] == \'\')) {
 					$new_img = str_replace(\'<img\', \'<img alt=\"\'.$title.\'\"\', $images[0][$index]);
 					$buffer = str_replace($images[0][$index], $new_img, $buffer);
 				}
 			}
 		}
 	}
  return $buffer;
 }  
function buffer_start() {
 ob_start();
 }  
function buffer_end() {
 echo callback(ob_get_clean());
 }  
add_action(\'wp\', \'buffer_start\', 0); add_action(\'wp_footer\', \'buffer_end\');

代码中虽然加了缓冲区,但还是会降低效率,建议安装静态缓存插件。

附其它方法:

function img_alt($content) {
 	global $post;
 	preg_match_all(\'/<img (.*?)/>/\', $content, $images);
 	if(!is_null($images)) {
 		foreach($images[1] as $index => $value) {
 			$new_img = str_replace(\'<img\', \'<img alt=\"\'.get_the_title().\'-\'.get_bloginfo(\'name\').\'\" title=\"\'.get_the_title().\'-\'.get_bloginfo(\'name\').\'\"\', $images[0][$index]);
 			$content = str_replace($images[0][$index], $new_img, $content);
 		}
 	}
 	return $content;
 } 
add_filter(\'the_content\', \'img_alt\', 99999);
温馨提示:本文最后更新于2022/10/20 04:08:11。若文章内容或图片失效,请留言联系站长反馈!
!
也想出现在这里? 联系我们
创意广告
© 版权声明
THE END
点赞0赞赏 分享
评论 抢沙发

请登录后发表评论

    请登录后查看评论内容