Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
3 / 1 / 0
Регистрация: 03.12.2018
Сообщений: 276

Фильтрация листа

14.10.2021, 22:29. Показов 447. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Необходимо отсортировать и отфильтровать товары на веб-сайте

Класс с товарами:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
package com.example.springwebapp.model;
 
import jdk.jfr.Category;
 
import java.awt.*;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.Date;
 
public class Product {
 
    private String title;
    private String description;
    private Integer price;
    private Object image;
    private Integer id;
    private String category;
 
    public Product(final String title,final String description, final Integer price, final Object image, final Integer id, final String category) {
        this.title = title;
        this.description = description;
        this.price = price;
        this.image = image;
        this.id = id;
        this.category = category;
    }
 
    public Object getImage() {
        return this.image;
    }
 
    public void setImage(final Object image) {
        this.image = image;
    }
 
    public String getTitle() {
        return this.title;
    }
 
    public void setTitle(final String title) {
        this.title = title;
    }
 
    public String getDescription() {
        return this.description;
    }
 
    public void setDescription(final String description) {
        this.description = description;
    }
 
    public Integer getPrice() {
        return this.price;
    }
 
    public void setPrice(final Integer price) {
        this.price = price;
    }
 
    public Integer getId() {
        return this.id;
    }
 
    public void setId(final Integer id) {
        this.id = id;
    }
 
    public String getCategory() {
        return this.category;
    }
 
    public void setCategory(final String category) {
        this.category = category;
    }
 
    public static final Comparator<Product> ascending = new Comparator<Product>() {
        @Override
        public int compare(Product lhs, Product rhs) {
            return lhs.getPrice() - rhs.getPrice();
        }
    };
 
    public static final Comparator<Product> descending = new Comparator<Product>() {
        @Override
        public int compare(Product lhs, Product rhs) {
            return rhs.getPrice() - lhs.getPrice();
        }
    };
 
    public static final Comparator<Product> alphabetically = new Comparator<Product>() {
        @Override
        public int compare(Product lhs, Product rhs) { return lhs.getTitle().compareTo(rhs.getTitle());}
    };
 
}
контроллер:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
package com.example.springwebapp.controller;
 
import com.example.springwebapp.model.Product;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
 
import javax.servlet.http.HttpSession;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Date;
 
 
@Controller
public class Home {
 
    @RequestMapping("/")
    /*public String home() {
        return "index";
    }*/
    public String homeWithSession(Model model, HttpSession session) {
        String sid = session.getId();
        model.addAttribute("sid", sid);
 
        ArrayList<Product> products = new ArrayList<>();
        products.add(new Product("Вязаный джемпер", "Повседневный вязаный свитер с высоким воротником, длинными рукавами на весну/осень",
                1080, "img/one.png",1,"top"));
 
        products.add(new Product("Куртка с карманом", "Повседневная куртка с капюшоном из искусственной кожи на осень/зиму",
                1460,"img/two.png",2,"top"));
 
        products.add(new Product("Свитер с принтом", "Повседневный пуловер с животным принтом на весну/осень",
                1320,"img/three.png",3,"top"));
 
        products.add(new Product("Юбка", "Свободна юбка с далматинским принтом и высоким разрезом сбоку",
                1220, "img/four.png",4,"bottom"));
 
        products.add(new Product("Брюки", "Прямые, свободные брюки палаццо из искуственной кожи с высокой посадкой",
                1660,"img/five.png",5,"bottom"));
 
        products.add(new Product("Футболка", "Повседневная футболка с круглым воротником и спущенными рукавами",
                330,"img/six.png",6,"top"));
 
        products.add(new Product("Джинсы", "Прямые, свободные джинсы с высокой талией и принтом на штанине",
                1890,"img/eight.png",7,"bottom"));
 
        products.add(new Product("Джинсы", "Широкие джинсы с высокой талией и мультипликационным принтом",
                1820,"img/seven.png",8,"bottom"));
 
        model.addAttribute("products", products);
        return "index";
    }
 
    /*@RequestMapping("/home-with-session")
    public String homeWithSession(Model model, HttpSession session) {
        String sid = session.getId();
        model.addAttribute("sid", sid);
 
        ArrayList<Product> products = new ArrayList<>();
        products.add(new Product("Old product", 1, new Date()));
        products.add(new Product("New product", 2, new Date()));
        model.addAttribute("products", products);
        return "index";
    }*/
    @RequestMapping("/sort")
    public String sort(Model model, HttpSession session) {
        String sid = session.getId();
        model.addAttribute("sid", sid);
        ArrayList<Product> products = new ArrayList<>();
        products.add(new Product("Вязаный джемпер", "Повседневный вязаный свитер с высоким воротником, длинными рукавами на весну/осень",
                1080, "img/one.png",1,"top"));
 
        products.add(new Product("Куртка с карманом", "Повседневная куртка с капюшоном из искусственной кожи на осень/зиму",
                1460,"img/two.png",2,"top"));
 
        products.add(new Product("Свитер с принтом", "Повседневный пуловер с животным принтом на весну/осень",
                1320,"img/three.png",3,"top"));
 
        products.add(new Product("Юбка", "Свободна юбка с далматинским принтом и высоким разрезом сбоку",
                1220, "img/four.png",4,"bottom"));
 
        products.add(new Product("Брюки", "Прямые, свободные брюки палаццо из искуственной кожи с высокой посадкой",
                1660,"img/five.png",5,"bottom"));
 
        products.add(new Product("Футболка", "Повседневная футболка с круглым воротником и спущенными рукавами",
                330,"img/six.png",6,"top"));
 
        products.add(new Product("Джинсы", "Прямые, свободные джинсы с высокой талией и принтом на штанине",
                1890,"img/eight.png",7,"bottom"));
 
        products.add(new Product("Джинсы", "Широкие джинсы с высокой талией и мультипликационным принтом",
                1820,"img/seven.png",8,"bottom"));
 
        model.addAttribute("products", products);
        Collections.sort(products, Product.ascending);
        return "index:: .main-content";
    }
 
    @RequestMapping("/sort1")
    public String sort1(Model model, HttpSession session) {
        String sid = session.getId();
        model.addAttribute("sid", sid);
        ArrayList<Product> products = new ArrayList<>();
        products.add(new Product("Вязаный джемпер", "Повседневный вязаный свитер с высоким воротником, длинными рукавами на весну/осень",
                1080, "img/one.png",1,"top"));
 
        products.add(new Product("Куртка с карманом", "Повседневная куртка с капюшоном из искусственной кожи на осень/зиму",
                1460,"img/two.png",2,"top"));
 
        products.add(new Product("Свитер с принтом", "Повседневный пуловер с животным принтом на весну/осень",
                1320,"img/three.png",3,"top"));
 
        products.add(new Product("Юбка", "Свободна юбка с далматинским принтом и высоким разрезом сбоку",
                1220, "img/four.png",4,"bottom"));
 
        products.add(new Product("Брюки", "Прямые, свободные брюки палаццо из искуственной кожи с высокой посадкой",
                1660,"img/five.png",5,"bottom"));
 
        products.add(new Product("Футболка", "Повседневная футболка с круглым воротником и спущенными рукавами",
                330,"img/six.png",6,"top"));
 
        products.add(new Product("Джинсы", "Прямые, свободные джинсы с высокой талией и принтом на штанине",
                1890,"img/eight.png",7,"bottom"));
 
        products.add(new Product("Джинсы", "Широкие джинсы с высокой талией и мультипликационным принтом",
                1820,"img/seven.png",8,"bottom"));
 
        model.addAttribute("products", products);
        Collections.sort(products, Product.descending);
        return "index:: .main-content";
    }
 
    @RequestMapping("/sort2")
    public String sort2(Model model, HttpSession session) {
        String sid = session.getId();
        model.addAttribute("sid", sid);
        ArrayList<Product> products = new ArrayList<>();
        products.add(new Product("Вязаный джемпер", "Повседневный вязаный свитер с высоким воротником, длинными рукавами на весну/осень",
                1080, "img/one.png",1,"top"));
 
        products.add(new Product("Куртка с карманом", "Повседневная куртка с капюшоном из искусственной кожи на осень/зиму",
                1460,"img/two.png",2,"top"));
 
        products.add(new Product("Свитер с принтом", "Повседневный пуловер с животным принтом на весну/осень",
                1320,"img/three.png",3,"top"));
 
        products.add(new Product("Юбка", "Свободна юбка с далматинским принтом и высоким разрезом сбоку",
                1220, "img/four.png",4,"bottom"));
 
        products.add(new Product("Брюки", "Прямые, свободные брюки палаццо из искуственной кожи с высокой посадкой",
                1660,"img/five.png",5,"bottom"));
 
        products.add(new Product("Футболка", "Повседневная футболка с круглым воротником и спущенными рукавами",
                330,"img/six.png",6,"top"));
 
        products.add(new Product("Джинсы", "Прямые, свободные джинсы с высокой талией и принтом на штанине",
                1890,"img/eight.png",7,"bottom"));
 
        products.add(new Product("Джинсы", "Широкие джинсы с высокой талией и мультипликационным принтом",
                1820,"img/seven.png",8,"bottom"));
 
        model.addAttribute("products", products);
        Collections.sort(products, Product.alphabetically);
        return "index:: .main-content";
    }
 
    @RequestMapping("/sort3")
    public String sort3(Model model, HttpSession session) {
        String sid = session.getId();
        model.addAttribute("sid", sid);
        ArrayList<Product> products = new ArrayList<>();
        products.add(new Product("Вязаный джемпер", "Повседневный вязаный свитер с высоким воротником, длинными рукавами на весну/осень",
                1080, "img/one.png",1,"top"));
 
        products.add(new Product("Куртка с карманом", "Повседневная куртка с капюшоном из искусственной кожи на осень/зиму",
                1460,"img/two.png",2,"top"));
 
        products.add(new Product("Свитер с принтом", "Повседневный пуловер с животным принтом на весну/осень",
                1320,"img/three.png",3,"top"));
 
        products.add(new Product("Юбка", "Свободна юбка с далматинским принтом и высоким разрезом сбоку",
                1220, "img/four.png",4,"bottom"));
 
        products.add(new Product("Брюки", "Прямые, свободные брюки палаццо из искусственной кожи с высокой посадкой",
                1660,"img/five.png",5,"bottom"));
 
        products.add(new Product("Футболка", "Повседневная футболка с круглым воротником и спущенными рукавами",
                330,"img/six.png",6,"top"));
 
        products.add(new Product("Джинсы", "Прямые, свободные джинсы с высокой талией и принтом на штанине",
                1890,"img/eight.png",7,"bottom"));
 
        products.add(new Product("Джинсы", "Широкие джинсы с высокой талией и мультипликационным принтом",
                1820,"img/seven.png",8,"bottom"));
 
        model.addAttribute("products", products);
        return "index:: .main-content";
    }
}
Сортировку сделала, но фильтрация совсем не получается. Еще, если можно, подскажите как сделать так, чтобы в контроллере не создавать постоянно лист со значениями. На сайте присутствует верхняя одежда и низ. Фильтрацию думала как раз делать по полю category - top/bottom
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.10.2021, 22:29
Ответы с готовыми решениями:

Сохранение текущего листа с сохранением имени листа и присвоением новой книге имени текущего листа
Sub Save_as() With Application.FileDialog(msoFileDialogSaveAs) .InitialFileName = ThisWorkbook.Path &amp; &quot;\&quot; &amp; &quot;new book name&quot;...

Сохранение листа книги в файле - проблема с защитой листа и привязкой макросов
С толкнулся с такой проблемой при сохранении листа в файле вот код который сохраняет лист в файле Sub red_row() ...

Запуск макроса (написанного для актив. нужного листа) с др. листа (сложно)
Подскажите пожалуйста, есть большие макросы которые работают на активном листе, существует какой-то способ не прописывая везде нужный лист...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.10.2021, 22:29
Помогаю со студенческими работами здесь

создание нового листа (заданного формата) с переносом данных с другого листа
Добрый день, формунчане! Большая просьба с созданием макроса. Необходимо разработать документ, который бы позволял создавать...

Перенос значений с одного листа в разные ячейки второго листа
прошу помощи, форумчане. Перед нами была поставлена задача оптимизировать наши расчеты. Суть оптимизации - на листе &quot;данные&quot;...

Считать данные с листа EXCEL в Listview. Выбор листа в Combobox
Как считать с листа Excel - где его имя - выбранное значение из combobox. Если я правильно понял то это событие ...

В ячейке B2 второго листа вывести значение ячейки A1 первого листа
Необходимо чтобы, например, в ячейке B2 второго листа автомотически вводилось значение ячейки A1 первого листа.

Сравнение множества столбцов листа со столбцом другого листа и выведение не совпавших данных
Доброго времени суток. Имеется какое-то количество столбцов фиксированной длинны с именами на первом листе, так же второй лист с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru