Преобразование строки в число и добавление одной

Я хочу повернуть значение, которое я получаю из идентификатора, в число и добавить его к нему, а затем передать новое значение в используемую функцию dosomething(). Когда я попробовал это, и значение одно, я вернусь 11, а не 2.

$('.load_more').live("click",function() { // When user clicks
    var newcurrentpageTemp = $(this).attr("id") + 1;// Get id from the hyperlink
    alert(parseInt(newcurrentpageTemp));
    dosomething();
});

Ответ 1

Предполагая, что вы верны, и ваш идентификатор является правильным номером (без какого-либо другого текста), вы должны проанализировать идентификатор и затем добавить его к нему:

var currentPage = parseInt($(this).attr('id'), 10);
++currentPage;

doSomething(currentPage);

Ответ 2

Вы пробовали немного сфотографировать его?

var newcurrentpageTemp = parseInt($(this).attr("id"));
newcurrentpageTemp++;
alert(newcurrentpageTemp));

Ответ 3

Я считаю, вы должны добавить 1 после передачи его parseInt

$('.load_more').live("click",function() { //When user clicks
          var newcurrentpageTemp = parseInt($(this).attr("id")) + 1;   
          alert(newcurrentpageTemp);
          dosomething();
      });

http://jsfiddle.net/GfqMM/

Ответ 4

$('.load_more').live("click",function() { //When user clicks
          var newcurrentpageTemp = parseInt($(this).attr("id")) + 1
          dosomething(newcurrentpageTemp );
      });

http://jsfiddle.net/GfqMM/

Ответ 5

Разберите идентификатор, как он будет строкой, а затем добавьте.

например.

$('.load_more').live("click",function() { //When user clicks
    var newcurrentpageTemp = parseInt($(this).attr("id")) + 1;//Get the id from the hyperlink
    alert(newcurrentpageTemp);
    dosomething();
});

Ответ 6

Вам нужно проанализировать идентификатор перед добавлением 1

 $('.load_more').live("click",function() { //When user clicks
              var newcurrentpageTemp = parseInt($(this).attr("id"));
              newcurrentpageTemp ++;
              dosomething(newcurrentpageTemp );
 });

Ответ 7

У меня это работает в аналогичной ситуации для перехода на следующую страницу следующим образом:

$("#page_next").click(function () {
    $("#pageNumber").val(parseInt($("#pageNumber").val()) + 1);
    submitForm(this);
    return false;
});

Вы должны иметь возможность добавлять скобки для достижения желаемого результата:

var newcurrentpageTemp = (parseInt($(this).attr("id"))) + 1;//Get the id from the hyperlink

Ответ 8

Самое простое решение здесь - изменить

  var newcurrentpageTemp = $(this).attr("id") + 1;//Get the id from the hyperlink

в

  var newcurrentpageTemp = (($(this).attr("id")) * 1) + 1;//Get the id from the hyperlink

Ответ 9

Решение parseInt - лучший способ, так как ясно, что происходит.

Для полноты стоит упомянуть, что это также можно сделать с помощью оператора +

$('.load_more').live("click",function() { //When user clicks
  var newcurrentpageTemp = +$(this).attr("id") + 1; //Get the id from the hyperlink
  alert(newcurrentpageTemp);
  dosomething();
});

Ответ 11

отличный способ от http://try.jquery.com/levels/4/challenges/16:

добавление + перед строкой без использования parseInt и parseFloat и radix и ошибок, с которыми я столкнулся с отсутствием параметра radix

Пример

var number= +$('#inputForm').val();

Ответ 12

var first_value = '2';
// convert this string value into int
parseInt(first_value);