Максимальная длина в текстовой области с использованием jQuery - PullRequest
6 голосов
/ 17 февраля 2010

Использование сценария off http://viralpatel.net/blogs/2008/12/set-maxlength-of-textarea-input-using-jquery-javascript.html Я пытаюсь ограничить ввод текстовой области до 1000 символов. Прототип также включен в страницу.

Отлично работает в chrome, но в firefox выдается следующая ошибка и ввод не ограничен:

$("textarea[maxlength]") is null

Я полностью в тупике. Любая помощь будет оценена. Ниже приведены фрагменты кода.

Текстовая область:

<%= text_area 'project', 'description', 'cols' => 60, 'rows' => 8, 'maxlength' => 1000 %>

JavaScript:

<%= javascript_include_tag "jquery", "jquery.maxlength" -%>
<script type="text/javascript">
  jQuery.noConflict();
  jQuery(document).ready(function($) {
    $().maxlength();
  })
</script>

jquery.maxlength.js:

jQuery.fn.maxlength = function(){
    $('textarea[maxlength]').keypress(function(event){
        var key = event.which;
        //all keys including return.
        if(key >= 33 || key == 13) {
            var maxLength = $(this).attr('maxlength');
            var length = this.value.length;
            if(length >= maxLength) {
                event.preventDefault();
            }
        }
    });
}

Ответы [ 2 ]

6 голосов
/ 17 февраля 2010

Оберните ваш jquery.maxlength.js файл в это:

(function($){
   .. existing code goes here
})(jQuery);

Когда вы вызываете $().maxlength(), он пытается использовать переменную $, но в другой области видимости, и он больше не равен jQuery. Оборачивая плагин в самозаполняющуюся анонимную функцию, он создает частную область видимости, где $ = jQuery

3 голосов
/ 17 февраля 2010

Поскольку jQuery установлен в режим noConflict () , вам нужно изменить jquery.maxlength.js на

(function($)
    $.fn.maxlength = function(){
        $('textarea[maxlength]').keypress(function(event){
            var key = event.which;
            //all keys including return.
            if(key >= 33 || key == 13) {
                var maxLength = $(this).attr('maxlength');
                var length = this.value.length;
                if(length >= maxLength) {
                    event.preventDefault();
                }
            }
        });
    };
})(jQuery);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...