Выбор формы Jquery не сохраняется после отправки - PullRequest
0 голосов
/ 29 августа 2011

Я использую скрипт jquery для выпадающих списков. Сценарий работает нормально, кроме того, что после отправки выбранный параметр не сохраняется как выбор, он по умолчанию возвращается к первым значениям каждого раскрывающегося списка.

Мне нужна помощь с этим. Есть ли решение, которое я могу добавить к одной из моих существующих публикаций или другой альтернативе.

Я использую два сценария, один для двухстороннего выбора двойных отбрасываний (одна капля зависит от другого), а другой - все параметры и их подопции.

Вот код для первого скрипта:

(function($) {
    $.fn.doubleSelect = function(doubleid, values, options) {

        options = $.extend({
            preselectFirst: null,
            preselectSecond: null,
            emptyOption: false,
            emptyKey: -1,
            emptyValue: 'Choose...'
        },
        options || {});

        var $first = this;
        var $secondid = "#" + doubleid;
        var $second = $($secondid);

        var setValue = function(value) {
            $second.val(value).change();
        };

        /** Helper Function to remove childs from second */
        var removeValues = function() {
            $($secondid + " option").remove();
        };

        /** OnChange Handler */
        $(this).change(function() {
            removeValues();
            var $current = this.options[this.selectedIndex].value;
            if ($current !== '') {
                $.each(values,
                function(k, v) {
                    var bestk;
                    if ($current == v.key) {
                        $.each(v.values,
                        function(k, v2) {
                            if (!bestk && (v.defaultvalue !== null && v2 == v.defaultvalue)) {
                                bestk = k;
                            }
                            if (options.preselectSecond !== null && v2 == options.preselectSecond) {
                                bestk = k;
                            }
                        });
                        $.each(v.values,
                        function(k, v2) {
                          var o = $("<option>").html(k).attr('value', v2);
                          if (options.preselectSecond) {
                            $.each(options.preselectSecond,
                              function(index, selected) {
                                if (v2 == selected) {
                                    o.html(k).attr("selected", "selected");
                                }
                              }
                            );
                          }
                          if (k === bestk) { o.html(k).attr("selected", "selected"); }
                          o.appendTo($second);
                        });
                    }
                });

            } else {
                setValue(options.emptyValue);
            }
        });

        return this.each(function() {

            //remove all current items in select boxes
            $first.children().remove();
            $second.children().remove();

            // Handle the empty option param
            if (options.emptyOption) {
                var oe = $("<option>").html(options.emptyValue).attr('value', options.emptyKey);
                oe.appendTo($first);
            }

            // add all options to first select box
            $.each(values,
            function(k, v) {
                var of = $("<option>").html(k).attr('value', v.key);
                if (options.preselectFirst !== null && v.key == options.preselectFirst) {
                    of.html(k).attr("selected", "selected");
                }
                of.appendTo($first);

            });

            if (options.preselectFirst === null) {
                var $current = this.options[this.selectedIndex].value;
                if ($current !== '') {
                    $.each(values,
                    function(k, v) {
                        var bestk;
                        if ($current == v.key) {
                            $.each(v.values,
                            function(k, v2) {
                                if (!bestk && (v.defaultvalue !== null && v2 == v.defaultvalue)) {
                                    bestk = k;
                                }
                                if (options.preselectSecond !== null && v2 == options.preselectSecond) {
                                    bestk = k;
                                }
                            });
                            $.each(v.values,
                            function(k, v2) {
                                var o = $("<option>").html(k).attr('value', v2);
                                if (k === bestk) { o.html(k).attr("selected", "selected"); }
                                o.appendTo($second);
                            });

                        }

                    });

                } else {
                    setValue(options.emptyValue);
                }
            } else {
                $first.change();
            }

        });

    };
})(jQuery); 

Вот пример кода из второго скрипта:

$(document).ready(function()
 {

    var selectoptions = {
            "Option 1": {
                 "key" : "Option 1",
                 "defaultvalue" : 1,
                 "values" : {
                    "sub-option 1": "sub-option 1",
                    "sub-option 2": "sub-option 2",
                    "sub-option 3": "sub-option 3"

          }
    },

"Option 2": {
                 "key" : "Option 1",
                 "defaultvalue" : 1,
                 "values" : {
                    "sub-option 1": "sub-option 1",
                    "sub-option 2": "sub-option 2",
                    "sub-option 3": "sub-option 3"

          }
    },

"Option 3": {
                 "key" : "Option 1",
                 "defaultvalue" : 1,
                 "values" : {
                    "sub-option 1": "sub-option 1",
                    "sub-option 2": "sub-option 2",
                    "sub-option 3": "sub-option 3"

          }
    },

 };

        $('#first').doubleSelect('second', selectoptions);

 });

Пример HTML-кода, который я использую:

<form action="" method="post" enctype="multipart/form-data"> 
<input type="hidden" name="action" value="1" />

<fieldset> 

<select type="text" name="address[state]" id="first" value="<?php // echo $_POST["address"]["state"]; ?>" class="short" tabindex="15"><option value="">--</option></select>

<select type="text" name="address[city]" id="second" value="<?php // echo $_POST["address"]["city"]; ?>" class="short" tabindex="16"><option value="">--</option></select>

</fieldset>                        

<input type="submit" name="submit" id="submit" class="button grey" tabindex="15" value="<?php echo SPEC($GLOBALS['_LANG']['_tpl_myaccount33']) ?>" />

</form>

Спасибо за любую помощь с этой проблемой. Цените это.

1 Ответ

1 голос
/ 29 августа 2011

Может быть потому, что в вашей форме нет action?

...