在做前端時我們希望用戶按要求提交數據了,如果提交了空我們就需要進入提示,在js中判斷表單為空我們直接使用xx==空就可以了,下面看實例。
例
<html> <script language="JavaScript"> function checkpost() { if(myform.keywords.value==""){alert("請輸入內容"); myform.keywords.focus(); return false; } if(myform.title.value.length<5){alert("請輸入標題"); myform.title.focus(); return false; } } </script><form action=search.php name="myform" onsubmit="return checkpost();"> 關鍵字:<input type="text" name="keywords"><br> 標題:<input type="text" name="title"> <input type="submit" value="查詢"> </form> </html>
解釋:
表單中onsubmit 控制提交后事件,return函數執行表單提交函數 值為false不提交,為true提交。然后用JS制作一個checkpost函數,來得到是false和ture.JS代碼中myform.title.focus(); 表示鼠標的焦點在title上myform.title.value.length<5表示title字段中,長度小于5時,警告和不執行
如果我們直接按幾個空格進去,上面的代碼肯定是可以通過的因為空格是字符串并不是空哦,我們可通過下面方法修正
第一種:循環檢查替換
[javascript]
//供使用者調用 function trim(s){ return trimRight(trimLeft(s)); } //去掉左邊的空白 function trimLeft(s){ if(s == null) { return ""; } var whitespace = new String(" tnr"); var str = new String(s); if (whitespace.indexOf(str.charAt(0)) != -1) { var j=0, i = str.length; while (j < i && whitespace.indexOf(str.charAt(j)) != -1){ j++; } str = str.substring(j, i); } return str; } //去掉右邊的空白 www.111cn.net function trimRight(s){ if(s == null) return ""; var whitespace = new String(" tnr"); var str = new String(s); if (whitespace.indexOf(str.charAt(str.length-1)) != -1){ var i = str.length - 1; while (i >= 0 && whitespace.indexOf(str.charAt(i)) != -1){ i--; } str = str.substring(0, i+1); } return str; }
第二種:正則替換
[javascript]
<SCRIPT LANGUAGE="JavaScript"> <!-- String.prototype.Trim = function() { return this.replace(/(^s*)|(s*$)/g, ""); } String.prototype.LTrim = function() { return this.replace(/(^s*)/g, ""); } String.prototype.RTrim = function() { return this.replace(/(s*$)/g, ""); } //--> </SCRIPT>
第三種:使用jquery
[javascript]
$.trim(str)
jquery內部實現為:
[javascript]
function trim(str){ return str.replace(/^(s|u00A0)+/,'').replace(/(s|u00A0)+$/,''); }
第四種:使用motools
[javascript]
function trim(str){ return str.replace(/^(s|xA0)+|(s|xA0)+$/g, ''); }
第五種:裁剪字符串方式
[javascript]
function trim(str){ str = str.replace(/^(s|u00A0)+/,''); for(var i=str.length-1; i>=0; i--){ if(/S/.test(str.charAt(i))){ str = str.substring(0, i+1); break; } } return str; }
經過測試第五種方法在處理長字符串時效率最高。
新聞熱點
疑難解答