解决hexo-matery主题站内搜索异常问题


在群里看到群友说搜索功能有问题,最开始我也没发现,搜索功能在主页没有问题在其他页面会因为添加这个页面的地址导致404.但是在观察友链其他人的网站没有发现问题,而我和群友的确实有问题。

解决过程

解决过程首先我怀疑是我的search.js文件的问题替换了友链其他人的,还是不行。
然后开始f12慢慢调试排查,我发现在searchlist里面显示的链接为不完整的链接如2020/111623576.html这样在主页没有问题在其他页面如 https://hesifan.top/contact/ 就会因为补全为 https://hesifan.top/contact/2020/111623576.html 导致404,我就开始改search.js文件将增加了一个 /

if (isMatch) {
                        str += "<li><a href='/" + data_url + "' class='search-result-title'>" + data_title + "</a>";

hexo d 之后正常,应该算是解决了吧,暂时还未出错。
贴上改后完整的js文件

var searchFunc = function (path, search_id, content_id) {
    'use strict';
    $.ajax({
        url: path,
        dataType: "xml",
        success: function (xmlResponse) {
            // get the contents from search data
            var datas = $("entry", xmlResponse).map(function () {
                return {
                    title: $("title", this).text(),
                    content: $("content", this).text(),
                    url: $("url", this).text()
                };
            }).get();
            var $input = document.getElementById(search_id);
            var $resultContent = document.getElementById(content_id);
            $input.addEventListener('input', function () {
                var str = '<ul class=\"search-result-list\">';
                var keywords = this.value.trim().toLowerCase().split(/[\s\-]+/);
                $resultContent.innerHTML = "";
                if (this.value.trim().length <= 0) {
                    return;
                }
                // perform local searching
                datas.forEach(function (data) {
                    var isMatch = true;
                    var content_index = [];
                    var data_title = data.title.trim().toLowerCase();
                    var data_content = data.content.trim().replace(/<[^>]+>/g, "").toLowerCase();
                    var data_url = data.url;
                    var index_title = -1;
                    var index_content = -1;
                    var first_occur = -1;
                    // only match artiles with not empty titles and contents
                    if (data_title != '' && data_content != '') {
                        keywords.forEach(function (keyword, i) {
                            index_title = data_title.indexOf(keyword);
                            index_content = data_content.indexOf(keyword);
                            if (index_title < 0 && index_content < 0) {
                                isMatch = false;
                            } else {
                                if (index_content < 0) {
                                    index_content = 0;
                                }
                                if (i == 0) {
                                    first_occur = index_content;
                                }
                            }
                        });
                    }
                    // show search results
                    if (isMatch) {
                        str += "<li><a href='/" + data_url + "' class='search-result-title'>" + data_title + "</a>";
                        var content = data.content.trim().replace(/<[^>]+>/g, "");
                        if (first_occur >= 0) {
                            // cut out 100 characters
                            var start = first_occur - 20;
                            var end = first_occur + 80;
                            if (start < 0) {
                                start = 0;
                            }
                            if (start == 0) {
                                end = 100;
                            }
                            if (end > content.length) {
                                end = content.length;
                            }
                            var match_content = content.substr(start, end);
                            // highlight all keywords
                            keywords.forEach(function (keyword) {
                                var regS = new RegExp(keyword, "gi");
                                match_content = match_content.replace(regS, "<em class=\"search-keyword\">" + keyword + "</em>");
                            });

                            str += "<p class=\"search-result\">" + match_content + "...</p>"
                        }
                        str += "</li>";
                    }
                });
                str += "</ul>";
                $resultContent.innerHTML = str;
            });
        }
    });
}

思考原因

这里是胡乱猜测,可能是因为我使用的生成链接是全数字,我发现其他人是随机或者拼音都没问题。


文章作者: 不染轻裳
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 不染轻裳 !
评论
 上一篇

阅读全文

我常用的一些快捷键
我常用的一些快捷键 我常用的一些快捷键
windows 剪贴板历史Windows键+V 访问剪贴板历史,粘贴历史复制内容 恢复不小心关闭的网页:Ctrl+Shift+T xshell 复制粘贴CTRL + ins shift + ins 重新连接shift +
2020-12-20
下一篇 

阅读全文

关于我的实验室
关于我的实验室 关于我的实验室
关于我的实验室:实验室内大部分页面都是我平时浏览大佬的博客发现的有趣的页面,然后用F12扒下来的。这些页面大多为开源项目,可以按照其说明自由引用,本人崇尚开源精神
2020-11-16
  目录