JQuery код работает в IE, но не Firefox / Chrome. - PullRequest
0 голосов
/ 28 июля 2011

Я делаю плагин JQuery самостоятельно. посмотрите на этот код:

<!DOCTYPE html>
<html>
<head>
    `<script type="text/Javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.js"></script>`
    <script type="text/javascript">
        // My plugin
        (function($) {
            $.html5 = {
                form: function() {
                    select = $('input');
                    $("input#number").after('<input type="button" id="step-up" value="U"><input type="button" id="step-down" value="D">');

                    $('input').bind('click', function(e){
                        if($(e.target).is("#step-up")){
                            $.html5.selector('min');
                            steps = parseInt(selector.attr('step'));
                            min = parseInt(selector.attr('min'));
                            max = parseInt(selector.attr('max'));
                            val = parseInt(selector.attr('value'));
                            if (val < max){
                                selector.val(val + steps);
                            }
                        }
                        if($(e.target).is("#step-down")){
                            $.html5.selector('min');
                            steps = parseInt(selector.attr('step'));
                            min = parseInt(selector.attr('min'));
                            max = parseInt(selector.attr('max'));
                            val = parseInt(selector.attr('value'));
                            if (val > min){
                                selector.val(val - steps);
                            }
                        }
                    });

                    increment = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
                    $.each(increment, function(index){
                        selector = $('input[placeholder]:eq(' + index + ')');
                        placeholder = selector.attr('placeholder');
                        selector.val(placeholder);
                    });

                    $(select).bind('focus', function(){
                        index = $(select).index(this);

                        // Placeholder
                        selector = $('input[placeholder]:eq(' + index + ')');
                        placeholder = selector.attr('placeholder');
                        if (selector.val() == placeholder)
                        {
                            selector.val('');
                        }

                        // Required
                        $('*').remove('.error');

                        //Min Max

                    });

                    $(select).bind('blur', function(){
                        index = $(select).index(this);

                        // Placeholder
                        selector = $('input[placeholder]:eq(' + index + ')');
                        placeholder = selector.attr('placeholder');
                        if (placeholder != selector.val() && selector.val() == '')
                        {
                            $(selector).val(placeholder);
                        }

                        // Required
                        $.html5.selector('required');
                        required = selector.attr('required');
                        if(required == 'required' && selector.val() == placeholder)
                        {
                            $(this + ':submit').attr('disabled','disabled');
                            $(this).after('<div class="error" style="border: 1px solid;">Required</div>');
                        }
                        else
                        {
                            $(this + ':submit').removeAttr('disabled');
                            $('*').remove('.error');
                        }

                        // Min Max
                        $.html5.selector('min');
                        min = selector.attr('min');
                        max = selector.attr('max');
                        val = parseInt(selector.val());
                        if(val > max) {
                            selector.val(max);
                        }
                        else if(val < min) {
                            selector.val(min);
                        }
                    });
                },
                selector: function(attr){
                    select = $('input');
                    attrib = $('input[' + attr + ']');
                    index = $(attrib).index(select);
                    selector = $('input[' + attr + ']:eq(' + index + ')');
                    return selector;
                }
            },
            form = function() {
                $.html5.form();
            }
        })(jQuery);

        // Call to my plugin
        $(document).ready( function() {
            form();
        });
    `</script>`
`</head>`
`<body>`
    `<form id="form" method="post" action="http://localhost/html5/">`
        `<input type="text" name="item" value="" placeholder="Enter text here." required="required" />`
        `<input type="number" name="number" min="5" max="10" step="1" value="" placeholder="Number here" id="number" />`
        `<input type="submit" value="Submit">`
    </form>
</body>
</html>

Мой плагин принимает параметры, такие как «min», «max» и «step» во входных файлах, таких как html5, но моя проблема в том, что мой плагин работает нормально в Internet Explorer, но не в Firefox / Chrome. Этот код получает значения переменных, таких как "min" и "max" в IE, но не в chrome, поэтому я не могу определить минимальное и максимальное значение полей ввода type = "number", как это делает html5. пожалуйста, помогите.

1 Ответ

2 голосов
/ 28 июля 2011

Просто выстрел в темноте - я считаю, что использование e.target может зависеть от браузера, вы можете попробовать использовать e.srcElement вместо этого.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...