[英]What's wrong with my first Jquery code and how can I accomplish this event?
我有一個快速的Jquery問題..如果單擊提交后根本沒有填滿輸入文本框,則此Jquery代碼應該在輸入文本框上顯示紅色邊框,此代碼來自書本,我完全按照代碼的方式進行復制,但我根本沒有紅色邊框,看起來好像沒有用..
另外,我想在表單的驗證過程中提供此代碼條件。.如果ESN列表文本字段的范圍是1000到3000,我希望下拉列表自動選擇下面的STM3輸入的數字介於5000到9000之間,我希望Trackpack在用戶在文本輸入字段上輸入6000后自動填充。在文本字段上輸入數字后,如何觸發下拉菜單? 對於新手來說太棘手了,我們將不勝感激。
<html>
<head> <title> Form </title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.0/jquery.min.js"></script>
<script type="text/javascript">
$(':submit').click(function(e) {
$(':text').each(function() {
if($(this.val().length == 0) {
$(this).css('border', '2px solid red');
}
});
e.preventDefault();
});
</script>
</head>
<body >
<form id="provision">
ESNList: <input type="text" id="ESNList" name="ESNList" size="30" /> <br />
ESN Start:<input type="text" id="ESNStart" name="ESNStart" size="10" /> <br />
ESN End: <input type="text" id="ESNStart" name="ESNStart" size="10" /> <br />
UnitName:<input type="text" id="STxName" name="STxName" size="30" /> <br />
Unit Model: <select name="STxName">
<option value="stx2">STX2</option>
<option value="protopak">Protopak</option>
<option value="stm3" selected>STM3</option>
<option value="acutec">Acutec</option>
<option value="mmt">MMT</option>
<option value="smartone">Trackpack</option>
<option value="smartoneb" >SmartOneB</option>
<option value="audi">Acutec</option>
</select> <br />
RTU Model Type:
<select name="rtumodel">
<option value="globalstar">GlobalStar</option>
<option value="both">Both</option>
<option value="comtech">Comtech</option>
<option value="stmcomtech">STMComtech</option>
</select> <br />
<input type="submit" value ="submit" />
</form>
</body>
</html>
您有一個錯字( $(this.val().length
應該是$(this).val().length
)。
$(':submit').click(function(e) {
e.preventDefault();
$(':text').each(function() {
if($(this).val().length == 0) {
$(this).css('border', '2px solid red');
}
});
});
一些想法:
e.preventDefault();
)。 $('input:text')
選擇器(而不是$(':text')
)。 基准測試表明它的性能要好得多。 if (this.value.length === 0)
替換if($(this).val().length == 0)...
有關工作示例,請參見http://jsfiddle.net/jhfrench/PvHGM/ 。
問題在於您不等待頁面加載來附加事件。 這在jQuery中很容易做到,只需將代碼括在$(function () {...});
正如我在下面所做的:
我還修正了一個錯字。
$(function () {
$(':submit').click(function(e) {
$(':text').each(function() {
var th = $(this);
if(th.val().length == 0) {
th.css('border', '2px solid red');
}
});
e.preventDefault();
});
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.