帝国cms后台编辑器上传图片将alt自动替换成文章标题title的办法

帝国cms后台发布内容自动把内容图片的alt和title替换为文章标题,需要修改/e/class/userfun.php,下面是青青模板网整理的关于本篇内容在“帝国cms常见问题”中的解决方案和思路,方便新手站长们在利用帝国cms建网站的时候,可以少走一些弯路。

操作方法如下:

1.把下面的代码放到/e/class/userfun.php (放到最后?>的前面)

<?php
//自动图片alt和title属性替换
function user_imgalt( $mid, $f, $isadd, $isq, $value, $cs ) {
  $title = $_POST[ 'title' ];
  $htmls = $value;
  $pattern = "/<img[^>]+>/";
  preg_match_all( $pattern, $htmls, $matches );
  for ( $i = 0; $i <= count( $matches[ 0 ] ); $i++ ) {
    preg_match_all( "/alt=\".+?\"/", $matches[ 0 ][ $i ], $altimg );
    preg_match_all( "/title=\".+?\"/", $matches[ 0 ][ $i ], $titleimg );
    $t_alt = count( $altimg[ 0 ] );
    if ( $t_alt == 0 ) {
      $htmls = str_replace( "<img", "<img alt=\"{$title}\"", $htmls );
      $htmls = str_replace( "<img", "<img title=\"{$title}\"", $htmls );
    }
  }
  return $htmls;
}
 
?>

2.在模型里正文字段一般是newstext(也可以是其它字段),在字段处理函数文本框填上user_imgalt 如下图:

这样在帝国cms后台发布信息的时候就可以自动替换图片alt和title属性为信息标题了!

方案二:

function user_AddImgAlt($mid,$f,$isadd,$isq,$value,$cs){
    $value=stripSlashes($value);
    $title=stripSlashes($_POST['title']);
    $title=str_replace('"','',$title);
    $zz2="/\<(img|IMG) (.*?)alt=\"(.*?)\"(.*?)>/is";
    $text=preg_replace($zz2,"<\\1 \\2\\4>",$value);
    $zz1="/\<(img|IMG) (.*?)>/is";
    $text=preg_replace($zz1,"<\\1 alt=\"{$title}\" title=\"{$title}\" \\2>",$text);
    return $text;
}


函数:user_AddImgAlt

以上就是关于帝国cms常见问题中"帝国cms后台编辑器上传图片将alt自动替换成文章标题title的办法"的全部内容,如果有遇到帝国cms常见问题其他问题的,可以在评论留言,或者加微信咨询。

帝国cms 编辑器 图片标题

本文链接:https://my.lmcjl.com/post/16138.html

展开阅读全文

4 评论

留下您的评论.