您现在的位置是:首页 > 网站制作 > WordpressWordpress
提高WordPress自带搜索功能体验
杰帅2023-08-26【Wordpress】人已围观
简介随着站内信息的增多,站内搜索成为了每个网站必不可少的功能。为了提高搜索体验,很多人采用Google Custom Search Engine服务作为站内搜索,可是使用搜索引擎进行站内搜索存在页面收录问题,因此对于新站是不实用的,因此使用WordPress提供的搜索功能是最 好的选择。相对于Google CSE,WordPress的搜索功能有两个明显不足:
随着站内信息的增多,站内搜索成为了每个网站必不可少的功能。为了提高搜索体验,很多人采用Google Custom Search Engine服务作为站内搜索,可是使用搜索引擎进行站内搜索存在页面收录问题,因此对于新站是不实用的,因此使用WordPress提供的搜索功能是最 好的选择。相对于Google CSE,WordPress的搜索功能有两个明显不足:
1、不能显示被检索到的条目数量;
2、关键词没有高亮。我们可以通过修改模板来添加这两个功能。
显示检索到的条目数量
打开主题的search.php(不同的主题可能有所不同),把下面的代码添加到适当的地方。
以下为引用的内容:
< ?php
/* Search Count */
$allsearch = &new WP_Query("s=$s&showposts=-1");
$key = wp_specialchars($s, 1);
$count = $allsearch->post_count;
echo '<span class="search-terms">'.$key.'</span> — '.$count.' articles';
wp_reset_query();
?>
这样例如在搜索“bolo”时,检索到10篇文章,在将会提示:bolo — 0 articles。
高亮关键词
在得到搜索结果以后,我们通常需要浏览一下条目的摘要,以选择一条自己觉得最符合要求的进行点击。高亮关键词,能是人们更快地找到自己所需要的条目。要增加这个功能,同样修改search.php。
以下为引用的内容:
//查找< ?php the_title(); ?>,替换成< ?php echo $title; ?>
//在< ?php echo $title; ?>前增加以下代码:
< ?php
$title = get_the_title();
$keys= explode(" ",$s);
$title = preg_replace('/('.implode('|', $keys) .')/iu', '<strong class="search-excerpt">\0', $title);
?>
这个代码可以加粗文章标题里的关键词,另外你也可以通过增加样式使关键词更加突出。
很赞哦! ()
相关文章
随机图文
-
wordpress发布文章HTML标签被自动过滤掉该如何处理?
wordpress发布文章时很多html标签都会自动过滤掉,造成了文章中无法添加<style></style><script></script>等标签。那么该如何如何处理呢? 解决方法一: 将wp-includes文件夹下 -
wp_reset_postdata 和 wp_reset_query 的作用与区别
什么时候使用wp_reset_query,什么时候用wp_reset_postdata? -
WordPress 页面模板(Page Template)下拉列表不显示的原因及解决方法
WordPress 的自定义页面模板是一个非常强大好用的功能,使用它新建一些静态页面(Page),添加上一些数据调用的函数,再在网页上做一个导航连接到对应的页面就可以实现很多自定义的功 -
wordpress 上传的图片不显示的问题 base64,data:image/gif
文章评论
本站推荐
标签云
猜你喜欢
- 网站被降权先别急先检查者四个方面
- WordPress函数get_the_author_link()
- 通过WP CLI一次性删除WordPress中未使用的图片 - 搬主题
- WordPress初学者入门教程 [01] 什么是WordPress?
- WordPress函数get_calendar()日历标签
- 如何修复WordPress中的403禁止错误
- WordPress网站实现分类文章排序及控制文章数量分页
- WordPress主题制作全过程(七):制作sidebar.php
- 33 charactersWordPress网站图片有损压缩与无损压缩有什么区别
- Bootstrap替换WordPress的get_search_form()搜索样式