如何给WordPress 单页面链接添加 .html 后缀

使用过wordpress的朋友都知道,wordpress可以选择好几种固定连接,一般来说,我们为了对搜索引擎友好,都会选择伪静态的固定连接。

伪静态连接其一是对搜索引擎友好,其二是如果我们想要对wordpress进行加速,伪静态链接也是必不可少的。

我们一般设置wordpress的固定连接,会使用2种形式的,一种是文章名形式的,一种是id形式的,而我们在设置的时候一般会加上html后缀,这样伪静态的url更加规范了,比如文本的链接:

https://www.mybj123.com/aboutus.html ‎

就是以html后缀形式结束的。

而如果在wordpress设置–固定连接加上html后缀之后,这个设置只能对wordpress的文章起作用,而对于wordpress的页面来说是不起作用的。

因此如果我们想要规范整站的url,那么也可以通过代码或者插件将我们的页面也加上html后缀

两种方式实现

方法一:使用插件.html on PAGES

在你的wordpress后台–插件–安装插件搜索.html on PAGES安装即可。

文章名: /%postname%.html

或者

数字连接(id): /%post_id%.html

两者皆可,如果是中文网站我们建议使用数字连接,因为如果中文网站的话,使用用文章名,还需要通过插件或者手工更改别名 ,比较麻烦。

需要注意的是,启用插件后还需要到后台固定链接设置中,重新保存一下设置,否则会跳到404页面,如果不成功可以先删除空间根目录的.htaccess文件,之后保存会自动生成新的。

方法二:使用代码(代码提取于.html on PAGES插件)

既然用插件可以实现,直接将插件中的代码集成到主题中同样也可以,代码提取自.html on PAGES插件,将下面代码添加主题functions.php中即可。

1
2
3
4
5
6
7
8
// 页面链接添加html后缀
add_action('init', 'html_page_permalink', -1);
function html_page_permalink() {
    global $wp_rewrite;
    if ( !strpos($wp_rewrite->get_page_permastruct(), '.html')){
        $wp_rewrite->page_structure = $wp_rewrite->page_structure . '.html';
    }
}

添加后,就生效了吗?当然没有,我们还需要到固定链接设置页面,重新保存一下固定链接设置,否则不会生效。

上述代码适合伪静态的固定链接形式使用,比如:

1
2
/%postname%.html
/%post_id%.html

效果如下:
如何给WordPress 单页面链接添加 .html 后缀
另外,如果同时给WordPress分类目录和页面添加斜杠如下代码:

1
2
3
4
5
6
function nice_trailingslashit($string, $type_of_url) {
    if ( $type_of_url != 'single' && $type_of_url != 'page' && $type_of_url != 'single_paged' )
        $string = trailingslashit($string);
    return $string;
}
add_filter('user_trailingslashit', 'nice_trailingslashit', 10, 2);

则还需要将该代码修改为:

1
2
3
4
5
6
7
// 添加斜杠
function nice_trailingslashit($string, $type_of_url) {
    if ( $type_of_url != 'single' && $type_of_url != 'page' )
      $string = trailingslashit($string);
    return $string;
}
add_filter('user_trailingslashit', 'nice_trailingslashit', 10, 2);

排除页面文件,否则页面链接.html后面也会自动加上斜杠。

想看具体实现效果在码云笔记网站底部有单页面,大家可以点进去试试

未经允许不得转载:码云笔记 » 如何给WordPress 单页面链接添加 .html 后缀
喜欢(0) 打赏

评论抢沙发

评论前必须登录!

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏

在线客服

在线客服

  • 扫描二维码,微信联系 扫描二维码,微信联系