我正在捐款网站上工作。在我的页面中,我有一个文本框,它接受用户的数值(即捐赠的钱)。
在我的代码隐藏中,我有一个方法可以检查文本框中的值是否为数字。如果数字无效,该方法将生成错误消息。
我还有一个JavaScript,在检查文本框中的值是数字后,在网站确认页面上打开一个新选项卡,感谢用户的捐赠。这是javascript的代码:
<script type="text/javascript">
function Open_Window()
{
var textbox = document.getElementById('DonationTextBox');
if (textbox.value != "")
{
if (isNan(textbox) == false)
{
window.open("DonationConfirmation.aspx")
}
}
}
</script>
问题是即使数字有效,标签也永远不会打开。你能帮我解决一下这个问题吗?谢谢。
P.S。
以下是启动验证的按钮代码:
<asp:ImageButton ID="PayPalButton2" runat="server" ImageAlign="Middle"
ImageUrl="Resources/Icons/PayPalCheckOut.gif"
onclick="PayPalButton2_Click" OnClientClick="Open_Window()"/>
答案 0 :(得分:3)
函数名称为isNaN
。注意:最终的'N'是资本。这应该可以解决你的问题。
答案 1 :(得分:2)
<script type="text/javascript">
function Open_Window()
{
var textbox = document.getElementById('<%=DonationTextBox.ClientID%>');
if (textbox.value != "" && !isNaN(textbox.value)) {
window.open("DonationConfirmation.aspx");
}
}
</script>
修改强>
而不是isNan应该是isNaN(javascript是区分大小写的)
答案 2 :(得分:1)
不应该这行...
if (isNan(textbox) == false)
相反......
if (isNan(textbox.value) == false)
答案 3 :(得分:1)
这是一个精简的工作jsFiddle示例:
http://jsfiddle.net/pjgalbraith/QZeSF/
html:
<a href="javascript:void(0)" id="PayPalButton2">Open</a>
<textarea id="donationTextBox">1</textarea>
和js:
function openWindow() {
if($('#donationTextBox').val() && isNaN($('#donationTextBox').val()) === false)
window.open("http://www.google.com/", "mywindow");
}
$(document).ready(function() {
$('#PayPalButton2').click(function(){
openWindow();
});
});
答案 4 :(得分:1)
首先,我建议显式解析数字,而不是依赖于将字符串传递给isNaN
时将应用的隐式ToNumber
操作。据推测,您的用户正在输入小数,因此如果它是一个整数(例如10),请使用:
var num = parseInt(textbox.value, 10);
如果它是一个带小数分量的数字(例如10.5),请使用:
var num = parseFloat(textbox.value);
您可能希望parseFloat
获得货币值。
然后if
上的isNaN
条件变为N
(请注意最终的num
上限){/ 1}}
<script type="text/javascript">
function Open_Window()
{
var textbox = document.getElementById('DonationTextBox');
var num = parseInt(textbox.value, 10);
if (!isNaN(num))
{
window.open("DonationConfirmation.aspx")
}
}
</script>
最后,你确定文本框的客户端ID真的是'DonationTextBox'吗? ASP自动生成客户端ID,您可能需要使用ClientID
,例如:
var textbox = document.getElementById('<%=DonationTextBox.ClientID%>');