72

一直在尝试将以下内容转换为数字:

<button class="btn btn-large btn-info" data-votevalue="1">
    <strong>1</strong>
</button>
var votevalue = parseInt($(this).data('votevalue'));

我也尝试过,但在检查结果时Number()我仍然得到。NaN我究竟做错了什么?

这是完整的代码:

<div class="span7" id="button-group">
    <div class="btn-group">
        <button class="btn btn-large btn-info" data-votevalue="1"><strong>1</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="2"><strong>2</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="3"><strong>3</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="4"><strong>4</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="5"><strong>5</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="6"><strong>6</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="7"><strong>7</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="8"><strong>8</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="9"><strong>9</strong></button>
        <button class="btn btn-large btn-info" data-votevalue="10"><strong>10</strong></button>
    </div>
</div>
$('#button-group button').each(function() {
    $(this).click(function() {
        $(this).addClass('active');
        var votevalue = parseInt($(this).data('votevalue'));
        var filename = $('.mainimage').data('filename');
        var votes = parseInt($('.mainimage').data('numvotes'));
        var totalscore = parseInt($('.mainimage').data('totalscore'));
        $.ajax({
            type: 'POST',
            url: 'index.php/?category=vote',
            data: {
                "votevalue": votevalue,
                "filename": filename
            },
            success: function() {
                votes++;
                alert(votes);
                var average = ((totalscore + votevalue) / votes);
                $('#vote-incremenet').html(votes);
                $('#display-average').html(average);
                $('#display-average').show();
                $('#button-group button').each(function(){
                    $(this).unbind('click');
                });
            }
        }); // end ajax
    }); // end click
}); // end each
4

9 回答 9

95

听起来this您的代码中没有指代您的.btn元素。尝试使用选择器显式引用它:

var votevalue = parseInt($(".btn").data('votevalue'), 10);

另外,不要忘记基数。

于 2012-10-11T12:35:04.780 回答
54

您可以使用parseInt(string, radix)将字符串值转换为整数,如下面的代码

var votevalue = parseInt($('button').data('votevalue'));
​

演示

于 2012-10-11T12:32:35.087 回答
32

虽然这是一篇旧文章,但我认为一个简单的函数可以使代码更具可读性并保持 jQuery 链接代码风格:

String.prototype.toNum = function(){
    return parseInt(this, 10);
}

可以与 jQuery 一起使用:

var padding_top = $('#some_div').css('padding-top'); //string: "10px"
var padding_top = $('#some_div').css('padding-top').toNum(); //number: 10`

或任何String物体:

"123".toNum(); //123 (number)`
于 2014-02-22T22:49:10.890 回答
11

对于您的情况,只需使用:

var votevalue = +$(this).data('votevalue');

有一些方法可以在 javascript 中将字符串转换为数字。

最好的方法:

var str = "1";
var num = +str; //simple enough and work with both int and float

您还可以:

var str = "1";
var num = Number(str); //without new. work with both int and float

或者

var str = "1";
var num = parseInt(str,10); //for integer number
var num = parseFloat(str); //for float number

不:

var str = "1";
var num = new Number(str);  //num will be an object. typeof num == 'object'

仅将 parseInt 用于特殊情况,例如

var str = "ff";
var num = parseInt(str,16); //255

var str = "0xff";
var num = parseInt(str); //255
于 2017-05-20T10:04:55.260 回答
8

您应该在 之前使用“+” $(this)。这会将字符串转换为数字,因此:

var votevalue = +$(this).data('votevalue');

哦,我建议使用closest()方法以防万一:)

var votevalue = +$(this).closest('.btn-group').data('votevalue');
于 2016-01-29T14:49:07.670 回答
5

听起来好像this是指的不是你想象的。您在什么情况下使用它?

this关键字通常仅在事件处理程序的回调函数中使用,当您循环一组元素或类似时。在这种情况下,它指的是特定的 DOM 元素,并且可以按照您的方式使用。

如果您只想访问该特定按钮(在任何回调或循环之外)并且没有任何其他使用btn-info该类的元素,您可以执行以下操作:

parseInt($(".btn-info").data('votevalue'), 10);

您还可以为元素分配一个 ID,并使用它进行选择,如果您想确保只有一个元素与您的选择器匹配,这可能是一种更安全的方式。

于 2012-10-11T12:33:16.203 回答
4

您可以+在字符串之前添加一个而不使用 parseInt 和 parseFloat 和 radix,简单

样本:

var votevalue = +$('button').data('votevalue');

alert(typeof(votevalue));
于 2015-09-18T14:51:40.683 回答
4

var string = 123(是字符串),

parseInt(参数为字符串);

var string = '123';

var int= parseInt(string );

console.log(int);  //Output will be 123.
于 2018-06-01T13:19:02.550 回答
0

var votevalue = $.map($(this).data('votevalue'), Number);

于 2018-12-12T21:34:03.550 回答