使用jquery过滤图像的相关问题



我正在使用jquery进行简单的图像过滤项目我有一个名为"数据类型"的数据属性,它包含多个值

例如:数据类型="科幻、警察、神秘、心理">

当我的数据类型有一个值时,比如data type="action",我可以过滤包含动作类型的图像(通过在选择框中选择动作类型(但正如你所知,一部动漫可以有多种类型,所以当我像上面的例子一样添加多个值时,它什么都不显示。我想要我的jquery代码,这样当我在选择框中选择警察类型时,它应该循环通过数据类型的多个值,并用警察类型显示图像

这是我的源代码

HTML代码:


<!DOCTYPE html>
<html lang="en">
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>

<title>Anime Filter</title>
<style>
*{
margin: 0 auto;
padding: 0 auto
box-sizing: border-box;
}
.an-filterbar{
text-align: center;
margin: 50px;
}
.ps-page{
margin: 100px;
}
.ps-page .ps-links{
margin-left: 30px;
float: left;
text-align: center;
}
</style>
</head>
<body>
<div class="an-filterbar">
<label for="an-search"><b>Type :</b></label>
<select class="type">
<option value="all">All</option>
<option value="tvseries">Tv series</option>
<option value="movie">Movie</option>
</select>
<br>
<label for="an-search"><b>Genre :</b></label>
<select class="genre">
<option value="all">All</option>
<option value="action">Action</option>
<option value="adventure">Adventure</option>
<option value="cars">Cars</option>
<option value="comedy">Comedy</option>
<option value="police">Police</option>
</select>
<br>
<label for="an-search"><b>Year :</b></label>
<select class="year">
<option value="all">All</option>
<option value="1990">1990</option>
<option value="1991">1991</option>
<option value="1992">1992</option>
<option value="1993">1993</option>
<option value="1994">1994</option>
</select>
<br>
<label for="an-search"><b>Season :</b></label>
<select class="season">
<option value="all">All</option>
<option value="winter">Winter</option>
<option value="spring">Spring</option>
<option value="summer">Summer</option>
<option value="fall">Fall</option>
</select>
<br>
<label for="an-search"><b>Status :</b></label>
<select class="status">
<option value="all">All</option>
<option value="airing">Airing</option>
<option value="finished">Finished</option>
<option value="notyetaired">Not yet Aired</option>
</select>
<br>
</div>
<div class="ps-page">
<div class="ps-links" data-type="movie" data-genre="adventure, comedy, action" data-year="1990" data-season="summer" data-status="notyetaired">
<a href="">
<figure>
<img src="assets/pimg-6.jpg" alt="Eizouken ni wa te wo dasu na">
<figcaption>
<b>Rating : N/R</b><br>
Eizouken ni wa te wo dasu na
</figcaption>
</figure>
</a>
</div>
<div class="ps-links" data-type="tvseries" data-genre="adventure, cars" data-year="1991" data-season="fall" data-status="airing">
<a href="">
<figure>
<img src="assets/pimg-7.jpg" alt="Somali to mori no kamisama">
<figcaption>
<b>Rating : N/R</b><br>
Somali to mori no kamisama
</figcaption>
</figure>
</a>
</div>
<div class="ps-links" data-type="tvseries" data-genre="action, comedy, cars" data-year="1992" data-season="summer" data-status="finished">
<a href="">
<figure>
<img src="assets/pimg-8.jpg" alt="Jibaku shounen hanako-kun">
<figcaption>
<b>Rating : N/R</b><br>
Jibaku shounen hanako-kun
</figcaption>
</figure>
</a>
</div>
<div class="ps-links" data-type="movie" data-genre="sci-fi, police, mystery, psychological" data-year="1993" data-season="spring" data-status="finished">
<a href="">
<figure>
<img src="assets/pimg-9.jpg" alt="Plunderer">
<figcaption>
<b>Rating : N/R</b><br>
Plunderer
</figcaption>
</figure>
</a>
</div>
</div>
<script>
$("select.type, select.genre, select.year, select.season, select.status").change(updateCategories);
function updateCategories() {
//get all the values
var caType = $('select.type').val();
var caGenre = $('select.genre').val();
var caYear = $('select.year').val();
var caSeason = $('select.season').val();
var caStatus = $('select.status').val();
$('.ps-page')
.find('.ps-links')
.hide()
.filter(function () {
var okcaType = true;
if(caType !== "all"){
okcaType = $(this).attr('data-type') === caType;
}
var okcaGenre = true;
if(caGenre !== "all"){
okcaGenre = $(this).attr('data-genre') === caGenre;
}
var okcaYear = true;
if(caYear !== "all"){
okcaYear = $(this).filter('data-year') === caYear;
}
var okcaSeason = true;
if(caSeason !== "all"){
okcaSeason = $(this).attr('data-season') === caSeason;
}
var okcaStatus = true;
if(caStatus !== "all"){
okcaStatus = $(this).attr('data-status') === caStatus;
}
//only fade a image if it satisfies all five conditions
return okcaType && okcaGenre && okcaYear && okcaSeason && okcaStatus;
}).fadeIn('fast');
}
</script>
</body>
</html>

试试这个代码,在选择框中选择一种类型,它不会显示任何图像

我想要这样一种解决方案,它应该适合我的代码(而不改变整个代码(,并解释它是如何工作的。

您需要将数据流派属性拆分到一个数组中,并检查所选流派是否存在于该数组中。

if (caGenre !== "all") {
var genreArray = $(this).attr('data-genre').split(",").map(function (item) { return item.trim(); })
okcaGenre = genreArray.indexOf(caGenre) !== -1;
}

正如您所看到的,我已经将数据类型字符串拆分为一个数组,并删除了每个项的周围空格。

更新的代码

function updateCategories() {
//get all the values
var caType = $('select.type').val() || 'all';
var caGenre = $('select.genre').val() || 'all';
var caYear = $('select.year').val() || 'all';
var caSeason = $('select.season').val() || 'all';
var caStatus = $('select.status').val() || 'all';

$('.ps-page')
.find('.ps-links')
.hide()
.filter(function () {
var okcaType = true;
if (caType !== "all") {
okcaType = $(this).attr('data-type') === caType;
}
var okcaGenre = true;
if (caGenre !== "all") {
var genreArray = $(this).attr('data-genre').split(",").map(function (item) { return item.trim(); })
okcaGenre = genreArray.indexOf(caGenre) !== -1;
}
var okcaYear = true;
if (caYear !== "all") {
okcaYear = $(this).filter('data-year') === caYear;
}
var okcaSeason = true;
if (caSeason !== "all") {
okcaSeason = $(this).attr('data-season') === caSeason;
}
var okcaStatus = true;
if (caStatus !== "all") {
okcaStatus = $(this).attr('data-status') === caStatus;
}
//only fade a image if it satisfies all five conditions
return okcaType && okcaGenre && okcaYear && okcaSeason && okcaStatus;
}).fadeIn('fast');
}

最新更新