龙坤云服务器

WordPress自动截取文章内容及标题字数的4种方法

释放双眼,带上耳机,听听看~!

 

使用wp_trim_words()截取

wordpress 3.3 新增了一个 wp_trim_words() 函数,专门用来截取限定字数的内容,比如文章、摘要、标题等。

<?php
echo wp_trim_words( get_the_content(), 100 ); // 文章内容
echo wp_trim_words( get_the_excerpt(), 100 ); // 文章摘要
echo wp_trim_words( get_the_title(), 100 ); // 文章标题
?>

 

当然,这个函数默认需要在循环中使用。

默认用法:

<?php $trimmed = wp_trim_words( $text, $num_words = 55, $more = null ); ?>

 

参数:

  • $text

    (字符串) (必需) 要截取的内容默认: 无

  • $num_words

    (整数) (可选) 限定的字数默认: 55

  • $more

    (字符串) (可选) 截取后加在尾部的字符默认: ‘&hellip;’

示例:

<?php
 
$content = get_the_content();
$trimmed_content = wp_trim_words( $content, 40, '<a href="'.%20get_permalink()%20.'"> ...阅读更多</a>' );
echo $trimmed_content;
 
?>

话说在制作wordpress主题的时候,我们通常要截取固定字数的文章标题,以保证主题样式的某些需求。

WordPress自动截取文章标题字数的4种方法

下面,倡萌就和大家分享下wordpress自动截取文章标题字数的4种方法。

通过原生函数截取

将下面的代码添加到主题的 functions.php 文件:

function customTitle($limit) {
    $title = get_the_title($post->ID);
    if(strlen($title) > $limit) {
        $title = substr($title, 0, $limit) . '...';
    }
 
    echo $title;
}

 

然后在输出文章标题的地方,使用下面的代码:

<?php customTitle(30); ?>

 

注:30为标题字数,请根据自己的需求修改。如果标题字数小于30,就显示完整标题;如果字数大于30,就截取30个字符,末尾自定添加…

通过自定义函数截取

//标题截断
function cut_str($src_str,$cut_length){$return_str='';$i=0;$n=0;$str_length=strlen($src_str);
		while (($n<$cut_length) && ($i<=$str_length))
		{$tmp_str=substr($src_str,$i,1);$ascnum=ord($tmp_str);
		if ($ascnum>=224){$return_str=$return_str.substr($src_str,$i,3); $i=$i+3; $n=$n+2;}
        elseif ($ascnum>=192){$return_str=$return_str.substr($src_str,$i,2);$i=$i+2;$n=$n+2;}
        elseif ($ascnum>=65 && $ascnum<=90){$return_str=$return_str.substr($src_str,$i,1);$i=$i+1;$n=$n+2;}
        else {$return_str=$return_str.substr($src_str,$i,1);$i=$i+1;$n=$n+1;}
    }
    if ($i<$str_length){$return_str = $return_str . '...';}
    if (get_post_status() == 'private'){ $return_str = $return_str . '(private)';}
    return $return_str;};

 

将上面的代码添加到主题的 functions.php 最后一个 ?> 的前面,然后在需要调用的地方添加下面的代码即可:

<?php echo cut_str($post->post_title,80); ?>

 

可以修改上面的数字来设定长度。

通过CSS来“截取”

严格来说,这不是截取,而是隐藏了溢出的字符。对标题所在的选择器 id 或 class 添加下面的样式:

.post-title{   width:250px; /* 限制宽度(可选) */   
white-space:nowrap; /* 禁止自动换行 */   
overflow:hidden; /* 隐藏溢出的内容 */   
text-overflow:ellipsis; /* 溢出文本使用...代替 */   }

 

人已赞赏
软件教程

ppt幻灯片怎么设置图片无限循环滚动呢?

2020-1-26 10:00:56

软件教程

网站比对数据库(mysql)升级教程

2020-2-20 22:03:35

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索