Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 1
Регистрация: 06.03.2010
Сообщений: 10

Динамические select и их нестандартное оформление

02.08.2013, 18:20. Показов 1948. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте

Возникла проблема - несколько часов убил, до конца не смог решить, прошу помощи у знатоков) С jquery плотно раньше не сталкивался, сегодня первый раз, поэтому прошу быть снисходительными.

Задача была - есть два селекта, при выборе в одном значении, во второй динамически подгружаются данные. Когда это просто обычные селекты мне сделать удалось, в принципе легко. Но проблема в том, что в вёрстке для оформления использовался скрипт, и вот вместе с ним дружить не захотели(

Проблему в принципе понял - селект скрывался, а отображались дивы с таким оформлением, стал загружать данные в эти дивы, всё заработало, списки выпадают. Но во втором списке нельзя выбирать значения, они не нажимаются, похоже слетели обработчики, как поправить разобраться не смог... Пробовал bind() менять на live() думал, вдруг поможет, но не то...

Мой код:
JavaScript
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
<script type="text/javascript">
 
$(document).ready(function()
    {
        $("#datet").change(function()
        {
 
            var id=$(this).val();
            var dataString = 'id='+ id;
            var s=$(".jquery-selectbox-list").last();
            var s2=$("#dateo");
            $.ajax
            ({
                type: "POST",
                url: "/ajax_master2.php",
                data: dataString,
                cache: false,
                success: function(html)
                            {
                                                                   s2.html(html);
                }
                });
                $.ajax
                ({
                type: "POST",
                url: "/ajax_master.php",
                data: dataString,
                cache: false,
                success: function(html)
                {
                                                                   s.html(html);
                }
                });
            });
        });
 
    </script>
    <div class="block-5" style="padding-bottom: 200px;">
        <div class="ns-select">
        <select name="datet" class="select" id="datet">
        <option  value="0">--Выберите услугу--</option>
        <option value='2'>маникюр</option>
        <option value='1'>педикюр</option>
        <option value='3'>стрижка</option>
        <option value='4'>укладка</option>
        </select>
        </div>
        <div class="ns-select">
        <select name="dateo"  class="select" id="dateo">
        <option value="0">--Любой мастер--</option>
        </select>
        </div>
        </div>
                   </div>
Вот что генерируется после выбора элемента из первого списка:

JavaScript
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
<div class="block-5" style="padding-bottom: 200px;">
 
<div class="ns-select">
    <div class="jquery-selectbox jquery-custom-selectboxes-replaced" style="width: 139.12px;">
        <div class="jquery-selectbox-moreButton"></div>
        <div class="jquery-selectbox-list jquery-custom-selectboxes-replaced-list" style="width: 134px; display: none;">
            <span class="jquery-selectbox-item value-0 item-0">--Выберите услугу--</span>
            <span class="jquery-selectbox-item value-2 item-1">маникюр</span>
            <span class="jquery-selectbox-item value-1 item-2">педикюр</span>
            <span class="jquery-selectbox-item value-3 item-3">стрижка</span>
            <span class="jquery-selectbox-item value-4 item-4">укладка</span>
        </div>
        <span class="jquery-selectbox-currentItem">педикюр</span>
 
        <select name="datet" class="select" id="datet" style="display: none;">
            <option value="0">--Выберите услугу--</option>
            <option value="2">маникюр</option>
            <option value="1">педикюр</option>
            <option value="3">стрижка</option>
            <option value="4">укладка</option>               
        </select>
    </div>
</div>
 
<div class="ns-select">
    <div class="jquery-selectbox jquery-custom-selectboxes-replaced" style="width: 124.08px;">
        <div class="jquery-selectbox-moreButton"></div>
        <div class="jquery-selectbox-list jquery-custom-selectboxes-replaced-list" style="width: 119px; display: none;">
            <span class="jquery-selectbox-item value-0 item-0">--Любой мастер--</span>
            <span class="jquery-selectbox-item value-1 item-1">Иван Иванов</span>
            <span class="jquery-selectbox-item value-2 item-2">Петр Петров</span>
        </div>
        <span class="jquery-selectbox-currentItem">--Любой мастер--</span>
        <select name="dateo" class="select" id="dateo" style="display: none;">
            <option value="0">--Любой мастер--</option>
            <option value="1">Иван Иванов</option>
            <option value="2">Петр Петров</option>
        </select>
    </div>
</div>
 
</div>
А вот код файла для применения стилей нестандартного оформления селектов:

JavaScript
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
jQuery.fn.selectbox = function(options){
    /* Default settings */
    var settings = {
        className: 'jquery-selectbox',
/*      animationSpeed: "normal",*/
        animationSpeed: "fast",
        listboxMaxSize: 10,
        replaceInvisible: false
    };
    var commonClass = 'jquery-custom-selectboxes-replaced';
    var listOpen = false;
    var showList = function(listObj) {
        var selectbox = listObj.parents('.' + settings.className + '');
        listObj.slideDown(settings.animationSpeed, function(){
            listOpen = true;
        });
        selectbox.addClass('selecthover');
        jQuery(document).bind('click', onBlurList);
        return listObj;
    }
    var hideList = function(listObj) {
        var selectbox = listObj.parents('.' + settings.className + '');
        listObj.slideUp(settings.animationSpeed, function(){
            listOpen = false;
            jQuery(this).parents('.' + settings.className + '').removeClass('selecthover');
        });
        jQuery(document).unbind('click', onBlurList);
        return listObj;
    }
    var onBlurList = function(e) {
        var trgt = e.target;
        var currentListElements = jQuery('.' + settings.className + '-list:visible').parent().find('*').andSelf();
        if(jQuery.inArray(trgt, currentListElements)<0 && listOpen) {
            hideList( jQuery('.' + commonClass + '-list') );
        }
        return false;
    }
 
    /* Processing settings */
    settings = jQuery.extend(settings, options || {});
    /* Wrapping all passed elements */
    return this.each(function() {
        var _this = jQuery(this);
        if(_this.filter(':visible').length == 0 && !settings.replaceInvisible)
            return;
        var replacement = jQuery(
            '<div class="' + settings.className + ' ' + commonClass + '">' +
                '<div class="' + settings.className + '-moreButton" />' +
                '<div class="' + settings.className + '-list ' + commonClass + '-list" />' +
                '<span class="' + settings.className + '-currentItem" />' +
            '</div>'
        );
        jQuery('option', _this).each(function(k,v){
            var v = jQuery(v);
            var listElement =  jQuery('<span class="' + settings.className + '-item value-'+v.val()+' item-'+k+'">' + v.text() + '</span>');
            listElement.click(function(){
                var thisListElement = jQuery(this);
                var thisReplacment = thisListElement.parents('.'+settings.className);
                var thisIndex = thisListElement[0].className.split(' ');
                for( k1 in thisIndex ) {
                    if(/^item-[0-9]+$/.test(thisIndex[k1])) {
                        thisIndex = parseInt(thisIndex[k1].replace('item-',''), 10);
                        break;
                    }
                };
                var thisValue = thisListElement[0].className.split(' ');
                for( k1 in thisValue ) {
                    if(/^value-.+$/.test(thisValue[k1])) {
                        thisValue = thisValue[k1].replace('value-','');
                        break;
                    }
                };
                thisReplacment
                    .find('.' + settings.className + '-currentItem')
                    .text(thisListElement.text());
                thisReplacment
                    .find('select')
                    .val(thisValue)
                    .triggerHandler('change');
                var thisSublist = thisReplacment.find('.' + settings.className + '-list');
                if(thisSublist.filter(":visible").length > 0) {
                    hideList( thisSublist );
                }else{
                    showList( thisSublist );
                }
            }).bind('mouseenter',function(){
                jQuery(this).addClass('listelementhover');
            }).bind('mouseleave',function(){
                jQuery(this).removeClass('listelementhover');
            });
            jQuery('.' + settings.className + '-list', replacement).append(listElement);
            if(v.filter(':selected').length > 0) {
                jQuery('.'+settings.className + '-currentItem', replacement).text(v.text());
            }
        });
        replacement.find('.' + settings.className + '-moreButton').click(function(){
            var thisMoreButton = jQuery(this);
            var otherLists = jQuery('.' + settings.className + '-list')
                .not(thisMoreButton.siblings('.' + settings.className + '-list'));
            hideList( otherLists );
            var thisList = thisMoreButton.siblings('.' + settings.className + '-list');
            if(thisList.filter(":visible").length > 0) {
                hideList( thisList );
            }else{
                showList( thisList );
            }
        }).bind('mouseenter',function(){
            jQuery(this).addClass('morebuttonhover');
        }).bind('mouseleave',function(){
            jQuery(this).removeClass('morebuttonhover');
        });
        _this.hide().replaceWith(replacement).appendTo(replacement);
        var thisListBox = replacement.find('.' + settings.className + '-list');
        var thisListBoxSize = thisListBox.find('.' + settings.className + '-item').length;
        if(thisListBoxSize > settings.listboxMaxSize)
            thisListBoxSize = settings.listboxMaxSize;
        if(thisListBoxSize == 0)
            thisListBoxSize = 1;
        var thisListBoxWidth = Math.round(_this.width() + 5);
        if(jQuery.browser.safari)
            thisListBoxWidth = thisListBoxWidth * 0.94;
        replacement.css('width', thisListBoxWidth + 'px');
        thisListBox.css({
            width: Math.round(thisListBoxWidth-5) + 'px'
        });
    });
}
jQuery.fn.unselectbox = function(){
    var commonClass = 'jquery-custom-selectboxes-replaced';
    return this.each(function() {
        var selectToRemove = jQuery(this).filter('.' + commonClass);
        selectToRemove.replaceWith(selectToRemove.find('select').show());
    });
}
 
$(document).ready(function() {
    // Custom select
    $('.select').selectbox();
    });
Понимаю, что вопрос объемный, буду рад любой помощи)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.08.2013, 18:20
Ответы с готовыми решениями:

Ссылка на выпадающий список и как изменить оформление <select>
Создаю тему в этом разделе, тк вряд ли чистым хтмл обойдется. Допустим есть всплывающее окно, в нем выпадающий список. 1 2 3 ...

динамические Select с группами
Дорогие друзья. Кто знает, подскажите. Как сделать динамически зависимые селекты (хотя бы, что бы 1-й зависел от 2-го), разделенные по...

Нестандартное оформление рабочей области
Как правило рабочая область сайта оформляется путем создания &quot;обойного&quot; фона, который повторяется на всем ее пространстве. Недавно...

3
 Аватар для Soldado
901 / 833 / 198
Регистрация: 28.06.2012
Сообщений: 1,607
Записей в блоге: 4
02.08.2013, 18:35
Попробуйте оn делегированно, live уже не поддерживается новыми библиотеками
типа так
JavaScript
1
2
3
4
$('body').on('change','#dateo', function(){
 
 
})
0
0 / 0 / 1
Регистрация: 06.03.2010
Сообщений: 10
02.08.2013, 18:40  [ТС]
Цитата Сообщение от Soldado Посмотреть сообщение
Попробуйте оn делегированно, live уже не поддерживается новыми библиотеками
типа так
JavaScript
1
2
$('body').on('change','#dateo', function(){
})
С jquery совсем туго, можно чуть подробнее, т.е. bind заменить на on?

Типа:
jQuery(document).bind('click', onBlurList);
на
jQuery(document).on('click', onBlurList);
0
0 / 0 / 1
Регистрация: 06.03.2010
Сообщений: 10
04.08.2013, 07:37  [ТС]
Ап, может кто-нибудь подскажет?)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.08.2013, 07:37
Помогаю со студенческими работами здесь

Нестандартное оформление окна программы
Как сделать чтобы оформление окна программы было не стандартное виндовское, а какое-нибудь другое красивое?

Нестандартное оформление списков с помощью css
Решил украсить нумерованные списки таким образом: ol { counter-reset: point; /* задаем переменную для счетчика */ list-style:...

Нестандартное оформление пункта меню при наведении
Можете помочь с оформлением меню, точнее как сделать. Вот пример: http://luiszuno.com/themes/halftone/index.html Там при наведении на...

Select оформление
Добрый вечер. Подскажите пожалуйста, как сверстать подобный &lt;select&gt; ? То есть, стиль скрола и высота выпадающего меню. Может есть...

Оформление тега select
Каким образом можно сделать нестандартное оформление тега select ? Нужно привести его с таком виду, как на картинке


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru