{"id":325551,"date":"2021-06-27T09:00:13","date_gmt":"2021-06-27T09:00:13","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=325551"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=325551","title":{"rendered":"\u0414\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0441\u043a\u0438\u0439 Multiselect \u043d\u0430 \u043f\u0440\u043e\u0442\u0435\u0438\u043d\u0430\u0445"},"content":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d73\/f09\/4a0\/d73f094a013bccc318ce10f5f1792a86.jpg\" alt=\"Multiselect\" title=\"Multiselect\" width=\"780\" height=\"440\"><figcaption>Multiselect<\/figcaption><\/figure>\n<p>\u0422\u0435 \u0438\u0437 \u0432\u0435\u0440\u0441\u0442\u0430\u043b\u044c\u0449\u0438\u043a\u043e\u0432 \u043a\u0442\u043e \u0447\u0430\u0441\u0442\u043e \u043a\u043b\u0435\u043f\u0430\u0435\u0442 \u0444\u043e\u0440\u043c\u044b \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0438\u043b\u0438 \u043e\u0431\u0440\u0430\u0442\u043d\u043e\u0439 \u0441\u0432\u044f\u0437\u0438 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u0442\u0441\u044f \u0441 \u0437\u0430\u0434\u0430\u0447\u0435\u0439 \u043f\u043e \u0432\u044b\u0432\u043e\u0434\u0443 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0433\u043e \u0432\u044b\u0431\u043e\u0440\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 &#8212; multiselect. \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043d\u0435 \u0432\u0441\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0442\u0435\u0433\u0430 <code>&lt;select&gt;<\/code> \u0432\u0441\u0435 \u0435\u0449\u0451 \u043c\u043e\u0436\u043d\u043e \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0441\u0442\u0438\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u043e \u0436\u0435\u043b\u0430\u043d\u0438\u044e \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0430.  \u0412 \u044d\u0442\u043e\u043c \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u043c \u0443\u0440\u043e\u043a\u0435 \u044f \u0445\u043e\u0442\u0435\u043b \u0431\u044b \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0441\u0432\u043e\u0438\u043c \u043e\u043f\u044b\u0442\u043e\u043c \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043d\u0430 \u0431\u0430\u0437\u0435 \u0437\u043d\u0430\u043d\u0438\u044f CSS \u0438 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0432\u0430\u043d\u0438\u043b\u044c\u043d\u043e\u0433\u043e JS. <\/p>\n<h2>\u0427\u0442\u043e \u043d\u0435 \u0442\u0430\u043a \u0441 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u043c select ?<\/h2>\n<p>\u0415\u0441\u043b\u0438 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440 \u0432\u0430\u043c \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u043b \u043a\u0440\u0430\u0441\u0438\u0432\u044b\u0439 <code>&lt;select&gt;<\/code> \u043d\u0430 10-15 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0432\u044b\u0431\u043e\u0440\u0430  \u0432\u044b \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043f\u0440\u0438\u0434\u0435\u0442\u0435 \u043a \u0440\u0435\u0448\u0435\u043d\u0438\u044e \u0432\u0437\u044f\u0442\u044c \u043f\u0435\u0440\u0432\u0443\u044e \u043f\u043e\u043f\u0430\u0432\u0448\u0443\u044e\u0441\u044f, \u043f\u043e\u0445\u043e\u0436\u0443\u044e \u043d\u0430 \u0434\u0438\u0437\u0430\u0439\u043d, \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0438\u0437 \u0433\u0443\u0433\u043b\u0430 (\u043d\u0430 \u0447\u0442\u043e \u044f \u043d\u0430\u0434\u0435\u044f\u043b\u0441\u044f).  \u041b\u0438\u0447\u043d\u0430\u044f \u0431\u043e\u043b\u044c \u0432 \u044d\u0442\u043e\u043c \u0432\u043e\u043f\u0440\u043e\u0441\u0435 \u0431\u044b\u043b\u0430 \u0441\u0432\u044f\u0437\u0430\u043d\u0430 \u0441 \u0442\u0435\u043c \u0447\u0442\u043e \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043d\u0435\u043b\u044c\u0437\u044f \u0431\u044b\u043b\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, \u043d\u0430 \u043f\u0440\u0438\u043c\u0435\u0440 jQuery \u0447\u0442\u043e \u043e\u0447\u0435\u043d\u044c \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u043b\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432.  <\/p>\n<h2>\u041e\u0442 \u043c\u0430\u043b\u043e\u0433\u043e \u043a \u0432\u0435\u043b\u0438\u043a\u043e\u043c\u0443<\/h2>\n<p>\u041d\u0443 \u0447\u0442\u043e \u0436 \u043f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u043c \u043a \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0433\u043e \u0432\u044b\u0431\u043e\u0440\u0430 \u0434\u043b\u044f \u0444\u043e\u0440\u043c\u044b:<\/p>\n<pre><code class=\"xml\">&lt;form class=\"createAccount\" name=\"\" action=\"\"&gt;   &lt;div class=\"form_label\"&gt;               &lt;span class=\"form_text\"&gt;Your technology&lt;\/span&gt;               &lt;div class=\"multiselect_block\"&gt;                 &lt;label for=\"select-1\" class=\"field_multiselect\"&gt;Technology&lt;\/label&gt;                 &lt;select id=\"select-1\" class=\"field_select\" name=\"technology\" multiple&gt;                   &lt;option value=\"all\"&gt;All&lt;\/option&gt;                   &lt;option value=\"HTML\"&gt;HTML&lt;\/option&gt;                   &lt;option value=\"CSS\"&gt;CSS&lt;\/option&gt;                   &lt;option value=\"JavaScript\"&gt;Java Script&lt;\/option&gt;                 &lt;\/select&gt;              &lt;\/div&gt;        &lt;span class=\"error_text\"&gt;&lt;\/span&gt;   &lt;\/div&gt; &lt;\/form&gt;<\/code><\/pre>\n<p>\u0415\u0441\u0442\u044c \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a \u0441\u0435\u043a\u0446\u0438\u0438, \u0435\u0441\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u0431\u043e\u0440\u0430 \u043e\u043f\u0446\u0438\u0439, \u0435\u0441\u0442\u044c <code>&lt;select&gt;<\/code>  \u0441 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u043c <code>multiple<\/code> \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u0430\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u044b\u0431\u043e\u0440 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e, \u0438 \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435 \u0435\u0441\u0442\u044c \u043f\u043e\u043b\u0435 <code>error_text<\/code> \u043a\u0443\u0434\u0430 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0441\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c \u0442\u0435\u043a\u0441\u0442 \u043e\u0431 \u043e\u0448\u0438\u0431\u043a\u0435 \u0435\u0441\u043b\u0438 \u044d\u0442\u043e\u0442 \u043c\u0443\u043b\u044c\u0442\u0438\u0441\u0435\u043b\u0435\u043a\u0442 \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043a \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044e<\/p>\n<figure class=\"float\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/f6a\/a63\/1d6\/f6aa631d61a7b78c8eb4a64fc078c87f.jpg\" width=\"289\" height=\"131\"><figcaption><\/figcaption><\/figure>\n<p>*\u0414\u043b\u044f \u043c\u0435\u043d\u044f \u0431\u044b\u043b\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u0438\u0435\u043c \u0447\u0442\u043e \u043c\u0443\u043b\u044c\u0442\u0438\u0432\u044b\u0431\u043e\u0440 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e\u043c \u0437\u0430\u0436\u0430\u0442\u0438\u044f \u043a\u043b\u0430\u0432\u0438\u0448\u0438 <strong>Ctrl<\/strong> \u0438\u043b\u0438 <strong>Shift<\/strong> \u0438 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435\u043c \u0442\u0435\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440. \u0412\u0438\u0434\u0430\u0442\u044c \u043d\u0435\u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0432 \u0441\u0432\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u0447\u0438\u0442\u0430\u043b \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e. <\/p>\n<p>\u0412\u0440\u043e\u0434\u0435 \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043d\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c. \u0414\u0430 \u0438 \u043c\u0443\u043b\u044c\u0442\u0438\u0441\u0435\u043b\u0435\u043a\u0442\u043d\u043e\u0441\u0442\u044c, \u043a\u0430\u043a-\u0442\u043e \u043d\u0435 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u0430&#8230;. \u0447\u0442\u043e \u0436\u0435 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0443\u043b\u0443\u0447\u0448\u0438\u043c.<\/p>\n<pre><code class=\"xml\">&lt;div class=\"form_label\"&gt;               &lt;span class=\"form_text\"&gt;Your technology&lt;\/span&gt;               &lt;div class=\"multiselect_block\"&gt;                 &lt;label for=\"select-1\" class=\"field_multiselect\"&gt;Technology&lt;\/label&gt;                 &lt;input id=\"checkbox-1\" class=\"multiselect_checkbox\" type=\"checkbox\"&gt;                 &lt;label for=\"checkbox-1\" class=\"multiselect_label\"&gt;&lt;\/label&gt;                 &lt;select id=\"select-1\" class=\"field_select\" name=\"technology\" multiple style=\"@media (min-width: 768px) { height: calc(4 * 38px)}\"&gt;                   &lt;option value=\"all\"&gt;All&lt;\/option&gt;                   &lt;option value=\"HTML\"&gt;HTML&lt;\/option&gt;                   &lt;option value=\"CSS\"&gt;CSS&lt;\/option&gt;                   &lt;option value=\"JavaScript\"&gt;Java Script&lt;\/option&gt;                 &lt;\/select&gt;                 &lt;span class=\"field_multiselect_help\"&gt;You can select several items by pressing &lt;b&gt;Ctrl(or Command)+Element&lt;\/b&gt;&lt;\/span&gt;               &lt;\/div&gt;               &lt;span class=\"error_text\"&gt;&lt;\/span&gt; &lt;\/div&gt;<\/code><\/pre>\n<p>\u0414\u043e\u0431\u0430\u0432\u0438\u043c \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0441\u0442\u0438\u043b\u0435\u0439, \u0447\u0442\u043e \u0431 \u043d\u0435 \u0431\u044b\u043b\u043e \u0442\u0430\u043a \u0441\u0442\u0440\u0430\u0448\u043d\u043e <\/p>\n<details class=\"spoiler\">\n<summary>CSS \u043d\u0430\u0448\u0435\u0433\u043e select<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"css\">.form_label {   position: relative;   min-height: 88px; }  .form_text {   vertical-align: top;   display: block;   margin-bottom: 6px;   font-weight: 500;   font-size: 12px;   line-height: 16px;   letter-spacing: 0.04em;   color: #686ea1; }  .form_text:after {   content: \"*\";   position: relative;   top: 0;   font-size: 13px;   color: #f00; }  .form_label input, .field_multiselect {   position: relative;   width: 100%;   display: block;   min-height: 46px;   border: 1px solid #cdd6f3;   box-sizing: border-box;   border-radius: 8px;   padding: 12px 40px 10px 16px;   font-size: 14px;   color: #a8acc9;   outline-color: #cdd6f3; } .form_label input::placeholder, .field_multiselect::placeholder {   color: #a8acc9; } .form_label input:hover, .field_multiselect:hover {   box-shadow: 0 0 2px rgba(0, 0, 0, 0.16); } .form_label input:focus, .field_multiselect:focus {   box-shadow: 0 0 2px rgba(0, 0, 0, 0.16); }  .field_multiselect_help {   position: absolute;   max-width: 100%;   background-color: #fff;   top: -48px;   left: 0;   opacity: 0; }  .form_label input.error {   border-color: #eb5757; }  .error_text {   color: #eb5757; }  .field_multiselect {   padding-right: 60px; } .field_multiselect:after {   content: \"\";   position: absolute;   right: 14px;   top: 15px;   width: 6px;   height: 16px;   background: url(\"data:image\/svg+xml,%3Csvg width='6' height='16' viewBox='0 0 6 16' fill='none' xmlns='http:\/\/www.w3.org\/2000\/svg'%3E%3Cpath d='M3 0L6 5H0L3 0Z' fill='%23A8ACC9'\/%3E%3Cpath d='M3 16L6 11H0L3 16Z' fill='%23A8ACC9'\/%3E%3C\/svg%3E\") 50% 50% no-repeat; }  .multiselect_block {   position: relative;   width: 100%; }  .field_select {   position: absolute;   top: calc(100% - 2px);   left: 0;   width: 100%;   border: 2px solid #cdd6f3;   border-bottom-right-radius: 2px;   border-bottom-left-radius: 2px;   box-sizing: border-box;   outline-color: #cdd6f3;   z-index: 6; }  .field_select[multiple] {   overflow-y: auto; }  .field_select option {   display: block;   padding: 8px 16px;   width: calc(370px - 32px);   cursor: pointer; } .field_select option:checked {   background-color: #eceff3; } .field_select option:hover {   background-color: #d5e8fb; }  .field_multiselect button {   position: relative;   padding: 7px 34px 7px 8px;   background: #ebe4fb;   border-radius: 4px;   margin-right: 9px;   margin-bottom: 10px; } .field_multiselect button:hover, .field_multiselect button:focus {   background-color: #dbd1ee; } .field_multiselect button:after {   content: \"\";   position: absolute;   top: 7px;   right: 10px;   width: 16px;   height: 16px;   background: url(\"data:image\/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http:\/\/www.w3.org\/2000\/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M19.4958 6.49499C19.7691 6.22162 19.7691 5.7784 19.4958 5.50504C19.2224 5.23167 18.7792 5.23167 18.5058 5.50504L12.5008 11.5101L6.49576 5.50504C6.22239 5.23167 5.77917 5.23167 5.50581 5.50504C5.23244 5.7784 5.23244 6.22162 5.50581 6.49499L11.5108 12.5L5.50581 18.505C5.23244 18.7784 5.23244 19.2216 5.50581 19.495C5.77917 19.7684 6.22239 19.7684 6.49576 19.495L12.5008 13.49L18.5058 19.495C18.7792 19.7684 19.2224 19.7684 19.4958 19.495C19.7691 19.2216 19.7691 18.7784 19.4958 18.505L13.4907 12.5L19.4958 6.49499Z' fill='%234F5588'\/%3E%3C\/svg%3E\") 50% 50% no-repeat;   background-size: contain; }  .multiselect_label {   position: absolute;   top: 1px;   left: 2px;   width: 100%;   height: 44px;   cursor: pointer;   z-index: 3; }  .field_select {   display: none; }  input.multiselect_checkbox {   position: absolute;   right: 0;   top: 0;   width: 40px;   height: 40px;   border: none;   opacity: 0; }  .multiselect_checkbox:checked ~ .field_select {   display: block; }  .multiselect_checkbox:checked ~ .multiselect_label {   width: 40px;   left: initial;   right: 4px;   background: #ffffff url(\"data:image\/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http:\/\/www.w3.org\/2000\/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M19.4958 6.49499C19.7691 6.22162 19.7691 5.7784 19.4958 5.50504C19.2224 5.23167 18.7792 5.23167 18.5058 5.50504L12.5008 11.5101L6.49576 5.50504C6.22239 5.23167 5.77917 5.23167 5.50581 5.50504C5.23244 5.7784 5.23244 6.22162 5.50581 6.49499L11.5108 12.5L5.50581 18.505C5.23244 18.7784 5.23244 19.2216 5.50581 19.495C5.77917 19.7684 6.22239 19.7684 6.49576 19.495L12.5008 13.49L18.5058 19.495C18.7792 19.7684 19.2224 19.7684 19.4958 19.495C19.7691 19.2216 19.7691 18.7784 19.4958 18.505L13.4907 12.5L19.4958 6.49499Z' fill='%234F5588'\/%3E%3C\/svg%3E\") 50% 50% no-repeat; }  .multiselect_checkbox:checked ~ .field_multiselect_help {   opacity: 1; }<\/code><\/pre>\n<\/div>\n<\/details>\n<figure class=\"float\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/f91\/8a8\/4d9\/f918a84d9450d768db8302287351442c.jpg\" width=\"387\" height=\"302\"><figcaption><\/figcaption><\/figure>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430 \u043d\u0435\u0433\u043e \u0445\u043e\u0442\u044c \u043f\u0440\u0438\u044f\u0442\u043d\u043e \u043d\u0430\u0436\u0438\u043c\u0430\u0442\u044c. SVG \u0438\u043a\u043e\u043d\u043a\u0438 \u044f \u0437\u0430\u0433\u043d\u0430\u043b \u0432 CSS, \u043d\u043e \u044d\u0442\u043e \u043d\u0435 \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u043e, \u0438 \u043b\u0443\u0447\u0448\u0435 \u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0438\u0445 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c\u044b\u043c\u0438 \u0444\u0430\u0439\u043b\u0430\u043c\u0438.  \u0414\u043b\u044f \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 <code>&lt;select&gt;<\/code>  \u042f \u0434\u043e\u0431\u0430\u0432\u0438\u043b <code>&lt;label class=\"multiselect_label\"&gt;<\/code>  \u0438 <code>&lt;input type=\"checkbox\" class=\"multiselect_checkbox\"&gt;<\/code> \u0422\u0443\u0442 \u0435\u0441\u0442\u044c \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043c\u0430\u0433\u0438\u0438 \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0441\u0432\u044f\u0437\u0430\u043d\u0430 \u0441 \u043f\u0435\u0440\u0435\u043a\u0440\u044b\u0442\u0438\u0435\u043c \u0441\u043b\u043e\u0435\u0432 \u0447\u0435\u0440\u0435\u0437 <strong>z-index<\/strong> \u0438 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0441 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438 \u0447\u0435\u0440\u0435\u0437 css \u043f\u0441\u0435\u0432\u0434\u043e\u043a\u043b\u0430\u0441\u0441 <code>:checked<\/code>. \u0421 \u0432\u0432\u0435\u0434\u0435\u043d\u0438\u0435\u043c \u044d\u0442\u0438\u0445 \u043d\u043e\u0432\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u0442\u0438\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0438 \u0438 \u0434\u0430\u0442\u044c \u043f\u043e\u043d\u044f\u0442\u044c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u0447\u0442\u043e \u043e\u043d \u0432\u044b\u0431\u0440\u0430\u043b.  \u042d\u0442\u043e \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0438\u0442 \u043b\u0443\u0447\u0448\u0438\u0435 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0441 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u043c. \u0420\u0430\u0441\u0448\u0438\u0440\u0438\u043c \u0435\u0449\u0451 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b \u0434\u043e\u0431\u0430\u0432\u0438\u0432 \u043a\u043d\u043e\u043f\u043a\u0438 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0432\u044b\u0431\u0440\u0430\u043d\u043d\u044b\u0445 \u043f\u0443\u043d\u043a\u0442\u043e\u0432.  <\/p>\n<pre><code class=\"javascript\">\/\/\/\/\/\/\/\/\/\/\/\/\/ Multiselect field      let multiselect_block = document.querySelectorAll(\".multiselect_block\");     multiselect_block.forEach(parent =&gt; {         let label = parent.querySelector(\".field_multiselect\");         let select = parent.querySelector(\".field_select\");         let text = label.innerHTML;         select.addEventListener(\"change\", function(element) {             let selectedOptions = this.selectedOptions;             label.innerHTML = \"\";             for (let option of selectedOptions) {                 let button = document.createElement(\"button\");                 button.type = \"button\";                 button.className = \"btn_multiselect\";                 button.textContent = option.value;                 button.onclick = _ =&gt; {                     option.selected = false;                     button.remove();                     if (!select.selectedOptions.length) label.innerHTML = text                 };                 label.append(button);             }         })     })<\/code><\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438 \u0432\u044b\u0431\u043e\u0440\u0435 <code>&lt;option&gt;<\/code> \u0432 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u043c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0435 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e \u043f\u043e\u043a\u0430\u0436\u0435\u0442 \u0447\u0442\u043e \u0437\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0431\u044b\u043b\u0438 \u0432\u044b\u0431\u0440\u0430\u043d\u044b \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u043c. \u0421 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e \u0438\u0445 \u0443\u0434\u0430\u043b\u0438\u0442\u044c. <\/p>\n<p> \u0422\u0430\u043a \u0436\u0435, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u044f \u0443\u0432\u0435\u0440\u0435\u043d, \u0447\u0442\u043e \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u044f \u043d\u0435 \u0437\u043d\u0430\u043b \u0447\u0442\u043e <code>&lt;select&gt;<\/code> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0434\u043b\u044f \u0432\u044b\u0431\u043e\u0440\u0430 \u0437\u0430\u0436\u0430\u0442\u044b\u0439 <strong>Ctrl<\/strong> \u0438\u043b\u0438 <strong>Shift<\/strong> \u0414\u043e\u0431\u0430\u0432\u0438\u043c \u044d\u0442\u0443 \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0443 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e. \u041c\u043e\u0436\u043d\u043e \u0431 \u0431\u044b\u043b\u043e \u0437\u0430\u0441\u0443\u043d\u0443\u0442\u044c \u0432 \u0442\u0443\u043b\u0442\u0438\u043f (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0432\u043e\u0434 \u0447\u0435\u0440\u0435\u0437 data \u0430\u0442\u0440\u0438\u0431\u0443\u0442), \u043d\u043e \u044f \u043f\u043e\u0434\u0443\u043c\u0430\u043b \u043e \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u0438 \u0438 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0430 \u044d\u0442\u043e\u0439 \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0438 \u043d\u0430 \u0434\u0440\u0443\u0433\u0438\u0435 \u044f\u0437\u044b\u043a\u0438. <\/p>\n<h2>\u0413\u043e\u0442\u043e\u0432\u044b\u0439 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 multiselect \u0434\u043b\u044f \u0431\u044b\u0441\u0442\u0440\u043e\u0439 \u0440\u0430\u0431\u043e\u0442\u044b<\/h2>\n<p>\u0412\u043e\u0442 \u0447\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c. \u0414\u043b\u044f \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e\u0441\u0442\u0438 \u0434\u043e\u0431\u0430\u0432\u0438\u043b \u0441\u0440\u0430\u0437\u0443 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432, \u0447\u0442\u043e \u0431 \u0431\u044b\u043b\u043e \u043f\u043e\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u0447\u0442\u043e \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u043c\u0430\u0441\u0448\u0442\u0430\u0431\u0438\u0440\u043e\u0432\u0430\u0442\u044c, \u043f\u0440\u043e\u0441\u0442\u043e \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044f \u043d\u0443\u0436\u043d\u044b\u0435 id \u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u043d\u044b\u0435 \u0441 \u043d\u0438\u043c\u0438 <code>&lt;label&gt;<\/code> \u0422\u0430\u043a\u0436\u0435 \u043e\u0442\u0434\u0435\u043b\u0438\u043b \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u044f\u043c\u0438 \u043d\u0443\u0436\u043d\u044b\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0447\u0442\u043e \u0431 \u0432\u044b \u043c\u043e\u0433\u043b\u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u044d\u0442\u043e\u0442 \u043a\u043e\u0434 \u0432 \u0441\u0432\u043e\u0438\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u0430\u0445 \u0434\u043b\u044f \u0443\u0434\u043e\u0431\u0441\u0442\u0432\u0430.<\/p>\n<p><iframe id=\"60d826689b18798fbe34cb63\" src=\"https:\/\/embedd.srv.habr.com\/iframe\/60d826689b18798fbe34cb63\" class=\"embed_video embed__content\" allowfullscreen=\"true\"><\/iframe><\/p>\n<p>\u041e\u043d \u043d\u0435 \u0438\u0434\u0435\u0430\u043b\u0435\u043d \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u043e\u0441\u0442\u0438, \u043d\u043e \u0443\u0436 \u043b\u0443\u0447\u0448\u0435 \u0442\u0430\u043a, \u0447\u0435\u043c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0438\u043b\u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0430 \u043f\u043e\u0434 jQuery. \u041f\u0440\u0435\u043b\u0435\u0441\u0442\u044c \u0442\u0435\u0433\u0430 <code>&lt;select&gt;<\/code>  \u0432 \u0442\u043e\u043c \u0447\u0442\u043e \u0434\u043b\u044f \u0441\u043c\u0430\u0440\u0442\u0444\u043e\u043d\u043e\u0432, \u0434\u0432\u0438\u0436\u043a\u0438 \u0441\u0430\u043c\u0438 \u043f\u043e\u043a\u0430\u0436\u0443\u0442 \u043c\u0443\u043b\u044c\u0442\u0438\u0432\u044b\u0431\u043e\u0440 \u043f\u0440\u0438 \u0444\u043e\u043a\u0443\u0441\u0435 \u043d\u0430 \u0442\u0435\u0433\u0435, \u0438 \u0432\u0430\u043c \u043d\u0435 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u044c\u0441\u044f \u0434\u0443\u043c\u0430\u0442\u044c \u043a\u0430\u043a \u0432\u043f\u0438\u0445\u043d\u0443\u0442\u044c 15-20 \u043f\u0443\u043d\u043a\u0442\u043e\u0432 \u0447\u0442\u043e \u0431 \u0432\u0435\u0440\u0441\u0442\u043a\u0430 \u043d\u0435 \u0441\u043b\u043e\u043c\u0430\u043b\u0430\u0441\u044c.<\/p>\n<p>\u041d\u0430\u0434\u0435\u044e\u0441\u044c \u043a\u043e\u043c\u0443-\u0442\u043e \u044d\u0442\u043e  \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u044b\u043c <\/p>\n<\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/564844\/\"> https:\/\/habr.com\/ru\/post\/564844\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"\n<div class=\"post__text post__text_v2\" id=\"post-content-body\">\n<figure class=\"full-width\"><figcaption>Multiselect<\/figcaption><\/figure>\n<p>\u0422\u0435 \u0438\u0437 \u0432\u0435\u0440\u0441\u0442\u0430\u043b\u044c\u0449\u0438\u043a\u043e\u0432 \u043a\u0442\u043e \u0447\u0430\u0441\u0442\u043e \u043a\u043b\u0435\u043f\u0430\u0435\u0442 \u0444\u043e\u0440\u043c\u044b \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u0438 \u0438\u043b\u0438 \u043e\u0431\u0440\u0430\u0442\u043d\u043e\u0439 \u0441\u0432\u044f\u0437\u0438 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0441\u0442\u043e\u043b\u043a\u043d\u0443\u0442\u0441\u044f \u0441 \u0437\u0430\u0434\u0430\u0447\u0435\u0439 \u043f\u043e \u0432\u044b\u0432\u043e\u0434\u0443 \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0433\u043e \u0432\u044b\u0431\u043e\u0440\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u043e\u0432 &#8212; multiselect. \u041a \u0441\u043e\u0436\u0430\u043b\u0435\u043d\u0438\u044e, \u043d\u0435 \u0432\u0441\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0442\u0435\u0433\u0430 <code>&lt;select&gt;<\/code> \u0432\u0441\u0435 \u0435\u0449\u0451 \u043c\u043e\u0436\u043d\u043e \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0441\u0442\u0438\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u043e \u0436\u0435\u043b\u0430\u043d\u0438\u044e \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440\u0430.  \u0412 \u044d\u0442\u043e\u043c \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u043c \u0443\u0440\u043e\u043a\u0435 \u044f \u0445\u043e\u0442\u0435\u043b \u0431\u044b \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0441\u0432\u043e\u0438\u043c \u043e\u043f\u044b\u0442\u043e\u043c \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043d\u0430 \u0431\u0430\u0437\u0435 \u0437\u043d\u0430\u043d\u0438\u044f CSS \u0438 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0432\u0430\u043d\u0438\u043b\u044c\u043d\u043e\u0433\u043e JS. <\/p>\n<h2>\u0427\u0442\u043e \u043d\u0435 \u0442\u0430\u043a \u0441 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u043c select ?<\/h2>\n<p>\u0415\u0441\u043b\u0438 \u0434\u0438\u0437\u0430\u0439\u043d\u0435\u0440 \u0432\u0430\u043c \u043d\u0430\u0440\u0438\u0441\u043e\u0432\u0430\u043b \u043a\u0440\u0430\u0441\u0438\u0432\u044b\u0439 <code>&lt;select&gt;<\/code> \u043d\u0430 10-15 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0432\u044b\u0431\u043e\u0440\u0430  \u0432\u044b \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043f\u0440\u0438\u0434\u0435\u0442\u0435 \u043a \u0440\u0435\u0448\u0435\u043d\u0438\u044e \u0432\u0437\u044f\u0442\u044c \u043f\u0435\u0440\u0432\u0443\u044e \u043f\u043e\u043f\u0430\u0432\u0448\u0443\u044e\u0441\u044f, \u043f\u043e\u0445\u043e\u0436\u0443\u044e \u043d\u0430 \u0434\u0438\u0437\u0430\u0439\u043d, \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u0438\u0437 \u0433\u0443\u0433\u043b\u0430 (\u043d\u0430 \u0447\u0442\u043e \u044f \u043d\u0430\u0434\u0435\u044f\u043b\u0441\u044f).  \u041b\u0438\u0447\u043d\u0430\u044f \u0431\u043e\u043b\u044c \u0432 \u044d\u0442\u043e\u043c \u0432\u043e\u043f\u0440\u043e\u0441\u0435 \u0431\u044b\u043b\u0430 \u0441\u0432\u044f\u0437\u0430\u043d\u0430 \u0441 \u0442\u0435\u043c \u0447\u0442\u043e \u0432 \u043f\u0440\u043e\u0435\u043a\u0442\u0435 \u043d\u0435\u043b\u044c\u0437\u044f \u0431\u044b\u043b\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0441\u0442\u043e\u0440\u043e\u043d\u043d\u0438\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, \u043d\u0430 \u043f\u0440\u0438\u043c\u0435\u0440 jQuery \u0447\u0442\u043e \u043e\u0447\u0435\u043d\u044c \u0441\u043e\u043a\u0440\u0430\u0442\u0438\u043b\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0445 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432.  <\/p>\n<h2>\u041e\u0442 \u043c\u0430\u043b\u043e\u0433\u043e \u043a \u0432\u0435\u043b\u0438\u043a\u043e\u043c\u0443<\/h2>\n<p>\u041d\u0443 \u0447\u0442\u043e \u0436 \u043f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u043c \u043a \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u043f\u0440\u043e\u0441\u0442\u043e\u0433\u043e \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0433\u043e \u0432\u044b\u0431\u043e\u0440\u0430 \u0434\u043b\u044f \u0444\u043e\u0440\u043c\u044b:<\/p>\n<pre><code class=\"xml\">&lt;form class=\"createAccount\" name=\"\" action=\"\"&gt;   &lt;div class=\"form_label\"&gt;               &lt;span class=\"form_text\"&gt;Your technology&lt;\/span&gt;               &lt;div class=\"multiselect_block\"&gt;                 &lt;label for=\"select-1\" class=\"field_multiselect\"&gt;Technology&lt;\/label&gt;                 &lt;select id=\"select-1\" class=\"field_select\" name=\"technology\" multiple&gt;                   &lt;option value=\"all\"&gt;All&lt;\/option&gt;                   &lt;option value=\"HTML\"&gt;HTML&lt;\/option&gt;                   &lt;option value=\"CSS\"&gt;CSS&lt;\/option&gt;                   &lt;option value=\"JavaScript\"&gt;Java Script&lt;\/option&gt;                 &lt;\/select&gt;              &lt;\/div&gt;        &lt;span class=\"error_text\"&gt;&lt;\/span&gt;   &lt;\/div&gt; &lt;\/form&gt;<\/code><\/pre>\n<p>\u0415\u0441\u0442\u044c \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043e\u043a \u0441\u0435\u043a\u0446\u0438\u0438, \u0435\u0441\u0442\u044c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0432\u044b\u0431\u043e\u0440\u0430 \u043e\u043f\u0446\u0438\u0439, \u0435\u0441\u0442\u044c <code>&lt;select&gt;<\/code>  \u0441 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u043e\u043c <code>multiple<\/code> \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0434\u0430\u0435\u0442 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0432\u044b\u0431\u043e\u0440 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043e\u0434\u043d\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e, \u0438 \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435 \u0435\u0441\u0442\u044c \u043f\u043e\u043b\u0435 <code>error_text<\/code> \u043a\u0443\u0434\u0430 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0441\u0431\u0440\u0430\u0441\u044b\u0432\u0430\u0442\u044c \u0442\u0435\u043a\u0441\u0442 \u043e\u0431 \u043e\u0448\u0438\u0431\u043a\u0435 \u0435\u0441\u043b\u0438 \u044d\u0442\u043e\u0442 \u043c\u0443\u043b\u044c\u0442\u0438\u0441\u0435\u043b\u0435\u043a\u0442 \u0431\u0443\u0434\u0435\u0442 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043a \u0437\u0430\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044e<\/p>\n<figure class=\"float\"><figcaption><\/figcaption><\/figure>\n<p>*\u0414\u043b\u044f \u043c\u0435\u043d\u044f \u0431\u044b\u043b\u043e \u043e\u0442\u043a\u0440\u044b\u0442\u0438\u0435\u043c \u0447\u0442\u043e \u043c\u0443\u043b\u044c\u0442\u0438\u0432\u044b\u0431\u043e\u0440 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043f\u043e\u0441\u0440\u0435\u0434\u0441\u0442\u0432\u043e\u043c \u0437\u0430\u0436\u0430\u0442\u0438\u044f \u043a\u043b\u0430\u0432\u0438\u0448\u0438 <strong>Ctrl<\/strong> \u0438\u043b\u0438 <strong>Shift<\/strong> \u0438 \u0443\u043a\u0430\u0437\u0430\u043d\u0438\u0435\u043c \u0442\u0435\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0430\u0434\u043e \u043e\u0442\u043f\u0440\u0430\u0432\u0438\u0442\u044c \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440. \u0412\u0438\u0434\u0430\u0442\u044c \u043d\u0435\u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u0432 \u0441\u0432\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u0447\u0438\u0442\u0430\u043b \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e. <\/p>\n<p>\u0412\u0440\u043e\u0434\u0435 \u043a\u0430\u043a \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043d\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c. \u0414\u0430 \u0438 \u043c\u0443\u043b\u044c\u0442\u0438\u0441\u0435\u043b\u0435\u043a\u0442\u043d\u043e\u0441\u0442\u044c, \u043a\u0430\u043a-\u0442\u043e \u043d\u0435 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u0430&#8230;. \u0447\u0442\u043e \u0436\u0435 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0443\u043b\u0443\u0447\u0448\u0438\u043c.<\/p>\n<pre><code class=\"xml\">&lt;div class=\"form_label\"&gt;               &lt;span class=\"form_text\"&gt;Your technology&lt;\/span&gt;               &lt;div class=\"multiselect_block\"&gt;                 &lt;label for=\"select-1\" class=\"field_multiselect\"&gt;Technology&lt;\/label&gt;                 &lt;input id=\"checkbox-1\" class=\"multiselect_checkbox\" type=\"checkbox\"&gt;                 &lt;label for=\"checkbox-1\" class=\"multiselect_label\"&gt;&lt;\/label&gt;                 &lt;select id=\"select-1\" class=\"field_select\" name=\"technology\" multiple style=\"@media (min-width: 768px) { height: calc(4 * 38px)}\"&gt;                   &lt;option value=\"all\"&gt;All&lt;\/option&gt;                   &lt;option value=\"HTML\"&gt;HTML&lt;\/option&gt;                   &lt;option value=\"CSS\"&gt;CSS&lt;\/option&gt;                   &lt;option value=\"JavaScript\"&gt;Java Script&lt;\/option&gt;                 &lt;\/select&gt;                 &lt;span class=\"field_multiselect_help\"&gt;You can select several items by pressing &lt;b&gt;Ctrl(or Command)+Element&lt;\/b&gt;&lt;\/span&gt;               &lt;\/div&gt;               &lt;span class=\"error_text\"&gt;&lt;\/span&gt; &lt;\/div&gt;<\/code><\/pre>\n<p>\u0414\u043e\u0431\u0430\u0432\u0438\u043c \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0441\u0442\u0438\u043b\u0435\u0439, \u0447\u0442\u043e \u0431 \u043d\u0435 \u0431\u044b\u043b\u043e \u0442\u0430\u043a \u0441\u0442\u0440\u0430\u0448\u043d\u043e <\/p>\n<details class=\"spoiler\">\n<summary>CSS \u043d\u0430\u0448\u0435\u0433\u043e select<\/summary>\n<div class=\"spoiler__content\">\n<pre><code class=\"css\">.form_label {   position: relative;   min-height: 88px; }  .form_text {   vertical-align: top;   display: block;   margin-bottom: 6px;   font-weight: 500;   font-size: 12px;   line-height: 16px;   letter-spacing: 0.04em;   color: #686ea1; }  .form_text:after {   content: \"*\";   position: relative;   top: 0;   font-size: 13px;   color: #f00; }  .form_label input, .field_multiselect {   position: relative;   width: 100%;   display: block;   min-height: 46px;   border: 1px solid #cdd6f3;   box-sizing: border-box;   border-radius: 8px;   padding: 12px 40px 10px 16px;   font-size: 14px;   color: #a8acc9;   outline-color: #cdd6f3; } .form_label input::placeholder, .field_multiselect::placeholder {   color: #a8acc9; } .form_label input:hover, .field_multiselect:hover {   box-shadow: 0 0 2px rgba(0, 0, 0, 0.16); } .form_label input:focus, .field_multiselect:focus {   box-shadow: 0 0 2px rgba(0, 0, 0, 0.16); }  .field_multiselect_help {   position: absolute;   max-width: 100%;   background-color: #fff;   top: -48px;   left: 0;   opacity: 0; }  .form_label input.error {   border-color: #eb5757; }  .error_text {   color: #eb5757; }  .field_multiselect {   padding-right: 60px; } .field_multiselect:after {   content: \"\";   position: absolute;   right: 14px;   top: 15px;   width: 6px;   height: 16px;   background: url(\"data:image\/svg+xml,%3Csvg width='6' height='16' viewBox='0 0 6 16' fill='none' xmlns='http:\/\/www.w3.org\/2000\/svg'%3E%3Cpath d='M3 0L6 5H0L3 0Z' fill='%23A8ACC9'\/%3E%3Cpath d='M3 16L6 11H0L3 16Z' fill='%23A8ACC9'\/%3E%3C\/svg%3E\") 50% 50% no-repeat; }  .multiselect_block {   position: relative;   width: 100%; }  .field_select {   position: absolute;   top: calc(100% - 2px);   left: 0;   width: 100%;   border: 2px solid #cdd6f3;   border-bottom-right-radius: 2px;   border-bottom-left-radius: 2px;   box-sizing: border-box;   outline-color: #cdd6f3;   z-index: 6; }  .field_select[multiple] {   overflow-y: auto; }  .field_select option {   display: block;   padding: 8px 16px;   width: calc(370px - 32px);   cursor: pointer; } .field_select option:checked {   background-color: #eceff3; } .field_select option:hover {   background-color: #d5e8fb; }  .field_multiselect button {   position: relative;   padding: 7px 34px 7px 8px;   background: #ebe4fb;   border-radius: 4px;   margin-right: 9px;   margin-bottom: 10px; } .field_multiselect button:hover, .field_multiselect button:focus {   background-color: #dbd1ee; } .field_multiselect button:after {   content: \"\";   position: absolute;   top: 7px;   right: 10px;   width: 16px;   height: 16px;   background: url(\"data:image\/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http:\/\/www.w3.org\/2000\/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M19.4958 6.49499C19.7691 6.22162 19.7691 5.7784 19.4958 5.50504C19.2224 5.23167 18.7792 5.23167 18.5058 5.50504L12.5008 11.5101L6.49576 5.50504C6.22239 5.23167 5.77917 5.23167 5.50581 5.50504C5.23244 5.7784 5.23244 6.22162 5.50581 6.49499L11.5108 12.5L5.50581 18.505C5.23244 18.7784 5.23244 19.2216 5.50581 19.495C5.77917 19.7684 6.22239 19.7684 6.49576 19.495L12.5008 13.49L18.5058 19.495C18.7792 19.7684 19.2224 19.7684 19.4958 19.495C19.7691 19.2216 19.7691 18.7784 19.4958 18.505L13.4907 12.5L19.4958 6.49499Z' fill='%234F5588'\/%3E%3C\/svg%3E\") 50% 50% no-repeat;   background-size: contain; }  .multiselect_label {   position: absolute;   top: 1px;   left: 2px;   width: 100%;   height: 44px;   cursor: pointer;   z-index: 3; }  .field_select {   display: none; }  input.multiselect_checkbox {   position: absolute;   right: 0;   top: 0;   width: 40px;   height: 40px;   border: none;   opacity: 0; }  .multiselect_checkbox:checked ~ .field_select {   display: block; }  .multiselect_checkbox:checked ~ .multiselect_label {   width: 40px;   left: initial;   right: 4px;   background: #ffffff url(\"data:image\/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http:\/\/www.w3.org\/2000\/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M19.4958 6.49499C19.7691 6.22162 19.7691 5.7784 19.4958 5.50504C19.2224 5.23167 18.7792 5.23167 18.5058 5.50504L12.5008 11.5101L6.49576 5.50504C6.22239 5.23167 5.77917 5.23167 5.50581 5.50504C5.23244 5.7784 5.23244 6.22162 5.50581 6.49499L11.5108 12.5L5.50581 18.505C5.23244 18.7784 5.23244 19.2216 5.50581 19.495C5.77917 19.7684 6.22239 19.7684 6.49576 19.495L12.5008 13.49L18.5058 19.495C18.7792 19.7684 19.2224 19.7684 19.4958 19.495C19.7691 19.2216 19.7691 18.7784 19.4958 18.505L13.4907 12.5L19.4958 6.49499Z' fill='%234F5588'\/%3E%3C\/svg%3E\") 50% 50% no-repeat; }  .multiselect_checkbox:checked ~ .field_multiselect_help {   opacity: 1; }<\/code><\/pre>\n<\/div>\n<\/details>\n<figure class=\"float\"><figcaption><\/figcaption><\/figure>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043d\u0430 \u043d\u0435\u0433\u043e \u0445\u043e\u0442\u044c \u043f\u0440\u0438\u044f\u0442\u043d\u043e \u043d\u0430\u0436\u0438\u043c\u0430\u0442\u044c. SVG \u0438\u043a\u043e\u043d\u043a\u0438 \u044f \u0437\u0430\u0433\u043d\u0430\u043b \u0432 CSS, \u043d\u043e \u044d\u0442\u043e \u043d\u0435 \u043e\u043f\u0442\u0438\u043c\u0430\u043b\u044c\u043d\u043e, \u0438 \u043b\u0443\u0447\u0448\u0435 \u0434\u0435\u0440\u0436\u0430\u0442\u044c \u0438\u0445 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c\u044b\u043c\u0438 \u0444\u0430\u0439\u043b\u0430\u043c\u0438.  \u0414\u043b\u044f \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 <code>&lt;select&gt;<\/code>  \u042f \u0434\u043e\u0431\u0430\u0432\u0438\u043b <code>&lt;label class=\"multiselect_label\"&gt;<\/code>  \u0438 <code>&lt;input type=\"checkbox\" class=\"multiselect_checkbox\"&gt;<\/code> \u0422\u0443\u0442 \u0435\u0441\u0442\u044c \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043c\u0430\u0433\u0438\u0438 \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0441\u0432\u044f\u0437\u0430\u043d\u0430 \u0441 \u043f\u0435\u0440\u0435\u043a\u0440\u044b\u0442\u0438\u0435\u043c \u0441\u043b\u043e\u0435\u0432 \u0447\u0435\u0440\u0435\u0437 <strong>z-index<\/strong> \u0438 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0441 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430\u043c\u0438 \u0447\u0435\u0440\u0435\u0437 css \u043f\u0441\u0435\u0432\u0434\u043e\u043a\u043b\u0430\u0441\u0441 <code>:checked<\/code>. \u0421 \u0432\u0432\u0435\u0434\u0435\u043d\u0438\u0435\u043c \u044d\u0442\u0438\u0445 \u043d\u043e\u0432\u044b\u0445 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u0441\u0442\u0438\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0438 \u0438 \u0434\u0430\u0442\u044c \u043f\u043e\u043d\u044f\u0442\u044c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u0447\u0442\u043e \u043e\u043d \u0432\u044b\u0431\u0440\u0430\u043b.  \u042d\u0442\u043e \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0438\u0442 \u043b\u0443\u0447\u0448\u0438\u0435 \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0441 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u043c. \u0420\u0430\u0441\u0448\u0438\u0440\u0438\u043c \u0435\u0449\u0451 \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b \u0434\u043e\u0431\u0430\u0432\u0438\u0432 \u043a\u043d\u043e\u043f\u043a\u0438 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0432\u044b\u0431\u0440\u0430\u043d\u043d\u044b\u0445 \u043f\u0443\u043d\u043a\u0442\u043e\u0432.  <\/p>\n<pre><code class=\"javascript\">\/\/\/\/\/\/\/\/\/\/\/\/\/ Multiselect field      let multiselect_block = document.querySelectorAll(\".multiselect_block\");     multiselect_block.forEach(parent =&gt; {         let label = parent.querySelector(\".field_multiselect\");         let select = parent.querySelector(\".field_select\");         let text = label.innerHTML;         select.addEventListener(\"change\", function(element) {             let selectedOptions = this.selectedOptions;             label.innerHTML = \"\";             for (let option of selectedOptions) {                 let button = document.createElement(\"button\");                 button.type = \"button\";                 button.className = \"btn_multiselect\";                 button.textContent = option.value;                 button.onclick = _ =&gt; {                     option.selected = false;                     button.remove();                     if (!select.selectedOptions.length) label.innerHTML = text                 };                 label.append(button);             }         })     })<\/code><\/pre>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438 \u0432\u044b\u0431\u043e\u0440\u0435 <code>&lt;option&gt;<\/code> \u0432 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u043c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0435 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u043a\u043d\u043e\u043f\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e \u043f\u043e\u043a\u0430\u0436\u0435\u0442 \u0447\u0442\u043e \u0437\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0431\u044b\u043b\u0438 \u0432\u044b\u0431\u0440\u0430\u043d\u044b \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0435\u043c. \u0421 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c\u044e \u0438\u0445 \u0443\u0434\u0430\u043b\u0438\u0442\u044c. <\/p>\n<p> \u0422\u0430\u043a \u0436\u0435, \u043f\u043e\u0441\u043a\u043e\u043b\u044c\u043a\u0443 \u044f \u0443\u0432\u0435\u0440\u0435\u043d, \u0447\u0442\u043e \u043d\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u044f \u043d\u0435 \u0437\u043d\u0430\u043b \u0447\u0442\u043e <code>&lt;select&gt;<\/code> \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 \u0434\u043b\u044f \u0432\u044b\u0431\u043e\u0440\u0430 \u0437\u0430\u0436\u0430\u0442\u044b\u0439 <strong>Ctrl<\/strong> \u0438\u043b\u0438 <strong>Shift<\/strong> \u0414\u043e\u0431\u0430\u0432\u0438\u043c \u044d\u0442\u0443 \u043f\u043e\u0434\u0441\u043a\u0430\u0437\u043a\u0443 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e. \u041c\u043e\u0436\u043d\u043e \u0431 \u0431\u044b\u043b\u043e \u0437\u0430\u0441\u0443\u043d\u0443\u0442\u044c \u0432 \u0442\u0443\u043b\u0442\u0438\u043f (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 \u0432\u044b\u0432\u043e\u0434<\/p>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-325551","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/325551","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=325551"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/325551\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=325551"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=325551"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=325551"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}