Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
4 / 4 / 2
Регистрация: 12.09.2013
Сообщений: 73

Использование this при подсчете количества символов

15.11.2013, 12:48. Показов 1758. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Только учусь, потому вопрос из разряда "для новичков".

Задача. Необходимо посчитать количество символов уже введенных (изначально загруженных, а не keyup) в input и вывести рядом с полем ввода.
Решение:

JavaScript
1
2
3
4
5
6
$(function() {
     var number = $("input[id='text-block']").val().length;
     var content = "Введено " + number;
     $("#block").html(content);
        
});
Выводим все это дело так:

HTML5
1
<input type="text" id="text-block"/><span id="block"></span>
Все хорошо, все работает. Не понимаю, что делать, если полей несколько и для каждого необходимо произвести подсчет:
HTML5
1
2
<input type="text" id="text-block"/><span id="block"></span>
<input type="text" id="text-block"/><span id="block"></span>

JavaScript
1
2
3
4
5
6
7
$(function() {
     var number = $("input[id='text-block']")*что здесь?*(function() {
           this.val().length;
           var content = "Введено " + number;
           $(*как сюда передать this?*"#block").html(content);
     }) 
});
Заранее благодарю.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.11.2013, 12:48
Ответы с готовыми решениями:

При подсчёте количества символов в файле показывает ноль
file = open('test.txt', 'r', encoding=&quot;utf-8-sig&quot;) print(file.read()) print('В данном файле ' + str(len(file.read())) + ' символов') ...

Дан текстовый файл. Вывести количество содержащихся в нем символов и строк (маркеры концов строк EOLN и конца файла EOF при подсчете количества символ
Дан текстовый файл. Вывести количество содержащихся в нем символов и строк (маркеры концов строк EOLN и конца файла EOF при подсчете...

Бесконечный цикл при подсчете количества строк!
Ситуация довольна странная. При подсчете строк в файле программа сваливается в бесконечный цикл. while(fscanf(ptr. &quot;%*%*c&quot;) ...

6
284 / 283 / 73
Регистрация: 06.05.2013
Сообщений: 1,613
15.11.2013, 15:26
HTML5
1
<input type="text" id="text-block"/><span id="block"></span>
id должен быть уникальным в пределах страницы.
Используйте class.



HTML5
1
<input type="text" class="text-block"/><span class="block"></span>
Вам это надо при загрузке страницы вывести всё?
0
4 / 4 / 2
Регистрация: 12.09.2013
Сообщений: 73
15.11.2013, 16:19  [ТС]
Нет, код несколько длиннее, выкладываю:

HTML5
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
<html><head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(function() {
    var number = $("input[class='text-block']").val().length;
    var content = "Введено " + number;
 
    
    $(".block").html(content);
 
    $("input[class='text-block']").keyup(function countRemainingChars(){
    
        maxchars = 50;
        number = $("input[class='text-block']").val().length;
        
        if(number <= maxchars){
            content = (maxchars - number) + " символов осталось";
        }
        if(number > maxchars) {
            content = "   <span style='color: red'>-" + (number - maxchars) + "</span> символов осталось";
        }
        
        $(".block").html(content);
        
    });
    
    
    
});
</script>
</head>
<body>
<input type="text" class="text-block"/><span class="block"></span><br>
<input type="text" class="text-block"/><span class="block"></span>
</body>
При загрузке страницы считается количество символов уже введенных в поле. Если содержимое изменяется, то показывается насколько, т.е. считается количество символов при keyup. На данный момент, при измененном ИД на КЛАСС получаем изменение содержимого на обеих строках.

Как мне указать, что нужно обрабатывать именно конкретное поле? Куда ж мне сунуть this?
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
15.11.2013, 16:57
Лучше полностью переделать, но стало лень и просто допилил ваш код:
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
$(function() {
 
 
    
    $(".block").html('Введено 0');
    var max = 50;
 
    $("input[class='text-block']").keyup(function countRemainingChars(){
  
 
        var number = $(this).val().length;
        var content = "Введено " + number;
        
        if(number <= max){
            content = (max - number) + " символов осталось";
        }
        if(number > max) {
            content = "   <span style='color: red'>-" + (number - max) + "</span> символов осталось";
        }
        
        $(this).next().html(content);
        
    });
    
    
});
1
4 / 4 / 2
Регистрация: 12.09.2013
Сообщений: 73
16.11.2013, 13:34  [ТС]
Не работает только один момент. Если в поле уже что-то вписано (при загрузке страницы), т.е. keyup не происходит, количество символов будет равно нулю. Как посчитать то, что уже введено?

JavaScript
1
2
3
4
5
6
7
$(function() {
 
    var number = $("input[class='text-block']").val().length;
        var content = "Введено " + number;
    
    $(".block").html(content);
});
так количество будет выводиться рядом со всеми полями. Куда добавить this?
0
 Аватар для vovandr
636 / 523 / 195
Регистрация: 19.08.2013
Сообщений: 1,400
16.11.2013, 14:32
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
$(function() {
 
    var max = 50;
    
    $(".block").each(function(){
        $(this).html('Осталось: ' + (max -  $(this).prev().val().length));
    });
    
    $("input[class='text-block']").keyup(function countRemainingChars(){
  
 
        var number = $(this).val().length;
        var content = "Введено " + number;
        
        if(number <= max){
            content = (max - number) + " символов осталось";
        }
        if(number > max) {
            content = "   <span style='color: red'>-" + (number - max) + "</span> символов осталось";
        }
        
        $(this).next().html(content);
        
    });
    
    
});
0
4 / 4 / 2
Регистрация: 12.09.2013
Сообщений: 73
16.11.2013, 15:39  [ТС]
вопрос решил, всем спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.11.2013, 15:39
Помогаю со студенческими работами здесь

Учет двух условий при подсчете количества объектов
Доброго времени суток! Возник следующий вопрос. нужно посчитать количество объектов, удовлетворяющих нескольким условиям: нужно...

Отображение нулевых строк в запросе при подсчёте количества
Есть 3 таблицы: Студенты, Ст_хобби и Хобби. В первой хранится группа, ФИО, контактные данные, № зачётки, в общем данные о студентах, во...

Использование всех ресурсов компьютера при подсчёте
При подсчёте у меня Maple ест 700Мб и загружает процессор на 25-27%. Можно ли заставить Maple (стоит 17я версия x64 на Win7x64)...

Найти ошибку при подсчете количества четных и нечетных чисел в матрице
Даны две целые квадратные матрицы четного порядка. Элементы массивов с четными номерами строки и столбца заменить нулем (стереть). ...

Что нужно изменить чтобы при подсчете количества обменов программа подсчитывала не один алгоритм сортировки
#include &lt;stdio.h&gt; //Подключение заголовочного файла библиотеки ввода/вывода #include &lt;locale.h&gt; //Подключение заголовочного файла...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
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