我正在尝试从开放图书馆的书api中获取数据,我已经在ui中获取了数据,但是找不到应该在哪里放置锚标记。 数据正在获取,但不知道在哪里放置锚标记,以便我可以调用该页面。 我想在用户搜索输入任何名称时获取记录,这部分完成了 现在我想将锚标记放在记录中的位置
var books = new Bloodhound({
datumTokenizer: Bloodhound.tokenizers.obj.whitespace,
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url: 'http://openlibrary.org/search.json?title=%QUERY',
wildcard: '%QUERY',
filter: function(searchResults) {
return $.map(searchResults.docs, function(searchResults) {
// console.log(searchResults.author_name);
// console.log("key is "+searchResults.key)
if (JSON.parse(sessionStorage.getItem("selectedBooks") == undefined || JSON.parse(sessionStorage.getItem("selectedBooks").indexOf(searchResults.title)) == -1)) {
return {
title: searchResults.title,
key: searchResults.key,
};
}
});
}
}
});
var authorsList = [];
var authors = new Bloodhound({
datumTokenizer: Bloodhound.tokenizers.obj.whitespace,
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url: 'http://openlibrary.org/search.json?author=%QUERY',
wildcard: '%QUERY',
filter: function(searchResults) {
return $.map(searchResults.docs, function(searchResults) {
if (searchResults.author_name !== undefined) {
var author = searchResults.author_name.toString();
}
if (authorsList.indexOf(author) == -1) {
authorsList.push(author);
return {
author_key: searchResults.author_key,
author: author,
};
}
});
},
}
});
$('#multiple-datasets .typeahead').typeahead({
highlight: true
}, {
name: 'books',
display: 'title',
source: books,
templates: {
header: '<h3 class="search">Books</h3>'
}
}, {
name: 'authors',
display: 'author',
source: authors,
templates: {
header: '<h3 class="search">Authors</h3>'
}
});
$('#multiple-datasets').bind('typeahead:selected', function(obj, datum, name) {
if (name == 'books') {
var selectedBooks = JSON.parse(sessionStorage.getItem("selectedBooks"));
if (selectedBooks == null) {
var a = [];
a.push(datum.title);
sessionStorage.setItem("selectedBooks", JSON.stringify(a));
} else {
selectedBooks.push(datum.title);
sessionStorage.setItem("selectedBooks", JSON.stringify(selectedBooks));
}
} else if (name == 'authors') {
var selectedAuthors = JSON.parse(sessionStorage.getItem("selectedAuthors"));
if (selectedAuthors == null) {
var a = [];
a.push(datum.author);
sessionStorage.setItem("selectedAuthors", JSON.stringify(a));
} else {
selectedAuthors.push(datum.author);
sessionStorage.setItem("selectedAuthors", JSON.stringify(selectedAuthors));
}
}
$('.typeahead').typeahead('val', '');
update_lists(JSON.parse(sessionStorage.getItem("selectedAuthors")), JSON.parse(sessionStorage.getItem("selectedBooks")));
});
update_lists(JSON.parse(sessionStorage.getItem("selectedAuthors")), JSON.parse(sessionStorage.getItem("selectedBooks")));
function update_lists(Authors, Books) {
$('#authorlist li').remove();
$('#booklist li').remove();
$.each(Authors, function(index, name) {
// console.log("Its author data"+authors.name);
$('#authorlist').append('<li><a href="#" >' + name + '</a></li>')
});
$.each(Books, function(index, name) {
console.log("Book Data" + books);
$('#booklist').append('<li><a href="#" >' + name + '</a></li>')
});
}
/* scaffolding */
/* ----------- */
.tt-menu,
.gist {
text-align: left;
}
/* base styles */
/* ----------- */
html {
font: normal normal normal 18px/1.2 "Helvetica Neue", Roboto, "Segoe UI", Calibri, sans-serif;
color: #292f33;
}
a {
color: #03739c;
text-decoration: none;
}
a:hover {
text-decoration: underline;
}
.table-of-contents li {
display: inline-block;
*display: inline;
zoom: 1;
}
.table-of-contents li a {
font-size: 16px;
color: #999;
}
p+p {
margin: 30px 0 0 0;
}
/* site theme */
/* ---------- */
.title {
margin: 20px 0 0 0;
font-size: 64px;
}
.example {
padding: 30px 0;
}
.example-name {
margin: 20px 0;
font-size: 32px;
}
.demo {
position: relative;
*z-index: 1;
margin: 50px 0;
}
.typeahead,
.tt-query,
.tt-hint {
width: 396px;
height: 30px;
padding: 8px 12px;
font-size: 24px;
line-height: 30px;
border: 2px solid #ccc;
-webkit-border-radius: 8px;
-moz-border-radius: 8px;
border-radius: 8px;
outline: none;
}
.typeahead {
background-color: #fff;
}
.typeahead:focus {
border: 2px solid #0097cf;
}
.tt-query {
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
-moz-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
}
.tt-hint {
color: #999
}
.tt-menu {
width: 600px;
margin: 12px 400px;
padding: 8px 0;
background-color: #fff;
border: 1px solid #ccc;
border: 1px solid rgba(0, 0, 0, 0.2);
-webkit-border-radius: 8px;
-moz-border-radius: 8px;
border-radius: 8px;
-webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, .2);
-moz-box-shadow: 0 5px 10px rgba(0, 0, 0, .2);
box-shadow: 0 5px 10px rgba(0, 0, 0, .2);
}
.tt-suggestion {
padding: 3px 20px;
font-size: 18px;
line-height: 24px;
}
.tt-suggestion:hover {
cursor: pointer;
color: #fff;
background-color: #0097cf;
}
.tt-suggestion.tt-cursor {
color: #fff;
background-color: #0097cf;
}
.tt-suggestion p {
margin: 0;
}
.gist {
font-size: 14px;
}
/* example specific styles */
/* ----------------------- */
#custom-templates .empty-message {
padding: 5px 10px;
text-align: center;
}
#multiple-datasets .league-name {
margin: 0 20px 5px 20px;
padding: 3px 0;
border-bottom: 1px solid #ccc;
}
#scrollable-dropdown-menu .tt-menu {
max-height: 150px;
overflow-y: auto;
}
#rtl-support .tt-menu {
text-align: right;
}
#multiple-datasets .search {
margin: 0 20px 5px 20px;
padding: 3px 0;
border-bottom: 1px solid #ccc;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script
src="http://code.jquery.com/jquery-3.3.1.min.js"
integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8="
crossorigin="anonymous"></script>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/corejs-typeahead/1.2.1/typeahead.bundle.min.js"></script>
<div id="multiple-datasets">
<form class="example" action="#">
<input class="typeahead" type="text" placeholder="Enter The Book Name to Search" name="search">
</form>
</div>
答案 0 :(得分:1)
用此代码替换您的脚本标签。会工作
<script>
var books = new Bloodhound({
datumTokenizer: Bloodhound.tokenizers.obj.whitespace,
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url: 'http://openlibrary.org/search.json?title=%QUERY',
wildcard: '%QUERY',
filter: function (searchResults) {
return $.map(searchResults.docs, function (searchResults) {
// console.log(searchResults.author_name);
// console.log("key is "+searchResults.key)
if (JSON.parse(sessionStorage.getItem("selectedBooks") == undefined || JSON.parse(sessionStorage.getItem("selectedBooks").indexOf(searchResults.title)) == -1)){
return {
title: searchResults.title,
key: searchResults.key,
};
}
});
}
}
});
var authorsList = [];
var authors = new Bloodhound({
datumTokenizer: Bloodhound.tokenizers.obj.whitespace,
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url: 'http://openlibrary.org/search.json?author=%QUERY',
wildcard: '%QUERY',
filter: function (searchResults) {
return $.map(searchResults.docs, function (searchResults) {
if (searchResults.author_name !== undefined){
var author = searchResults.author_name.toString();
}
if (authorsList.indexOf(author) == -1) {
authorsList.push(author);
return {
author_key: searchResults.author_key,
author: author,
};
}
});
},
}
});
$('#multiple-datasets .typeahead').typeahead({
highlight: true
},
{
display: 'title',
source: books,
templates: {
header: '<h3 class="search">Books List</h3>'
}
},
{
name: 'authors',
display: 'author',
source: authors,
templates: {
header: '<h3 class="search">Authors List</h3>'
}
});
$('#multiple-datasets').bind('typeahead:selected', function(obj, datum, name) {
console.log(datum);
if (name === 'authors'){
var request = $.ajax({
type: 'POST',
url: `http://localhost:9090/history`,
data: {author: datum.author}
});
request.done(function (msg) {
window.location.href="/author/authors/" +datum.author_key[0];
});
request.fail(function (jqXHR,textStatus) {
alert("Request Failed"+textStatus);
});
}
else
{
var request = $.ajax({
type: 'POST',
url: `http://localhost:9090/history`,
data: {book: datum.title}
});
request.done(function (msg) {
window.location.href="/book" +datum.key;
});
request.fail(function (jqXHR,textStatus) {
alert("Request Failed"+textStatus);
});
}
});
</script>