Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
17mie32
GitHub Repository: 17mie32/17mie32.github.io
Path: blob/main/js/search.js
1317 views
1
var searchFunc = function (path, search_id, content_id) {
2
'use strict';
3
$.ajax({
4
url: path,
5
dataType: "xml",
6
success: function (xmlResponse) {
7
// get the contents from search data
8
var datas = $("entry", xmlResponse).map(function () {
9
return {
10
title: $("title", this).text(),
11
content: $("content", this).text(),
12
url: $("url", this).text()
13
};
14
}).get();
15
var $input = document.getElementById(search_id);
16
var $resultContent = document.getElementById(content_id);
17
$input.addEventListener('input', function () {
18
var str = '<ul class=\"search-result-list\">';
19
var keywords = this.value.trim().toLowerCase().split(/[\s\-]+/);
20
$resultContent.innerHTML = "";
21
if (this.value.trim().length <= 0) {
22
return;
23
}
24
// perform local searching
25
var cnt = 1;
26
datas.forEach(function (data) {
27
var isMatch = true;
28
var content_index = [];
29
var data_title = data.title.trim().toLowerCase();
30
var data_content = data.content.trim().replace(/<[^>]+>/g, "").toLowerCase();
31
var data_url = data.url;
32
var index_title = -1;
33
var index_content = -1;
34
var first_occur = -1;
35
// only match artiles with not empty titles and contents
36
if (data_title != '' && data_content != '') {
37
keywords.forEach(function (keyword, i) {
38
index_title = data_title.indexOf(keyword);
39
index_content = data_content.indexOf(keyword);
40
if (index_title < 0 && index_content < 0) {
41
isMatch = false;
42
} else {
43
if (index_content < 0) {
44
index_content = 0;
45
}
46
if (i == 0) {
47
first_occur = index_content;
48
}
49
}
50
});
51
}
52
// show search results
53
if (isMatch) {
54
str += "<li><a href='" + data_url + "' class='search-result-title'>" + String(cnt) + ". " + data_title + "</a>";
55
cnt += 1;
56
57
var content = data.content.trim().replace(/<[^>]+>/g, "");
58
if (first_occur >= 0) {
59
// cut out 100 characters
60
var start = first_occur - 20;
61
if (start < 0) {
62
start = 0;
63
}
64
var match_content = content.substr(start, 100);
65
// highlight all keywords
66
keywords.forEach(function (keyword) {
67
var regS = new RegExp(keyword, "gi");
68
match_content = match_content.replace(regS, "<em class=\"search-keyword\">" + keyword + "</em>");
69
});
70
71
str += "<p class=\"search-result\">" + match_content + "...</p>"
72
}
73
str += "</li>";
74
}
75
});
76
str += "</ul>";
77
str = "<p class=\"search-result-summary\">共找到" + String(cnt-1) + "条结果</p>" + str;
78
$resultContent.innerHTML = str;
79
});
80
}
81
});
82
}
83
84