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

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

wpdaxue.com-201304558

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

使用wp_trim_words()截取

WordPress 3.3 新增了一个 wp_trim_words() 函数,专门用来截取限定字数的内容,比如文章、摘要、标题等,使用方法请看:https://www.wpdaxue.com/wp_trim_words.html

通过原生函数截取

将下面的代码添加到主题的 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; /* 溢出文本使用...代替 */

}

如果你还知道其他截取标题字数的更好方法,欢迎和我们一起分享。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
欢迎关注我们的微信公众号:WPDAXUE

倡萌

一个文科IT宅男,喜欢折腾WordPress和被它折腾 ^_^

17 条评论

  1. 第三种 方法是可以 但是 如果显示时间的话 长点的标题又把时间弄的下一行显示了 又变成了 两行

  2. 我发现源生函数字数只能固定双倍叠加,如30,60,90… 否则出现方框。

  3. 这个方法不过,原生函数和自定义函数有什么区别么?
    或者说那种函数更好?

    1. 所谓原生,是指WordPress自身的函数,如果借助它自身的函数就可以实现了,就不必要自己再创建自定义函数了

    2. 如果你制作的是自适应的主题,最好还是通过css来控制

  4. 想问下,怎么能实现你用的主题侧边栏标题的截取方法呢?显示是“标题….",查看源码是整体的标题。

    1. 给li加css样式 ,核心代码: width:250px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;

        1. [img]http://bbs.crsky.com/1236983883/Mon_1305/221_213191_5b6fac1d7ed8817.png[/img]

      1. 非常谢谢,这个方法要比上面介绍的方法好,网站做的很棒 !加油!

    2. 这是4月15日的评论,竟然出现在4月19日的文章里,倡萌转移评论能不能把时间也改一下

      1. 其实是将老文章的发布日期改了,让它显示为“新文章”

  5. 您好,操作过多次了,我的主题为什么实现不了呢?

发表评论

您的电子邮箱地址不会被公开。 必填项已用*标注