javascript - 求和而不是连接

标签 javascript

我试图在单击时将输入文本值增加 1。这是一项非常简单的任务,但我无法使其正常工作。这是代码:

<script type="text/javascript">
$('#field').bind('click', function(){
    old_value = $(this).attr('value');
    $(this).attr('value', (old_value+1));
})
</script>
<form action="">
    <input type="text" value="1" id="field"/>
</form>

点击输入后,它的值不会增加。取而代之的是,数字 1 被添加到值的末尾,即点击 3 次后输入值为 1111。你知道我做错了什么吗?提前致谢。

最佳答案

您需要进行类型转换,因为所有表单值都作为字符串传递。

$('#field').bind('click', function(){
    old_value = parseInt($(this).attr('value'), 10);
    $(this).attr('value', (old_value+1));
})

Whatever you do don't forget to pass a radix (base) through to the parseInt function!

如果你忘记了,这可能会发生:

parseInt("010") # 8 

关于javascript - 求和而不是连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9526126/

相关文章:

javascript - isBetween 使用时刻时区

javascript - ReactJS 中的 setState

javascript - 选择 div 的子字段

javascript - Vue + TypeScript - 用于放置自定义类型的推荐文件夹结构约定?

javascript - 多次点击监听器 - javascript

javascript - React Js 使用不同的文件更改变量

javascript - 为什么这个 yield generator 在 javascript 中的迭代次数是错误的?

javascript - 为什么 twitter bootstrap 输入 :focus:invalid:focus triggered when novalidate is used?

javascript - Jest 无法使用 toHaveProperty 验证属性的存在

Javascript 正则表达式流行语