实用Javascript 传值, 数据验证, 事件触发总结

2008-02-23 07:50:11来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

  实用Javascript 传值, 数据验证, 事件触发总结

  1. 和JSP传值问题:


  1)普通提交form 的数据验证传值

  html页面输入:

<form onsubmit="return checkForm1(this);" name =”form1”>

<input…..>

</form>


Javascript 获得值并处理:

<script language=”javascript ”>

function checkForm1(text1)

{

if(text1.name.value==””)

{alert(“null”);

return false;

}

return true;

}

</script>

  这里相当于传递一个指针过去到javascript 的function , 该指针指向form 里面的所有元素.引用的时候不用再写form1.name.value 代之以text1.name.value.当然如果非要那样写,不用传递this指针了.我倾向于传递this指针的用法.


  2)窗口和窗口之间的传值

  html 页面链接:


<a href="javascript:openwin(<%=rs.getString("article_id")%>)" title="<%=rs.getString("title")%>" />


<script>

function openwin(id){

window.open("articleShow.jsp?id=" id,"","height=450,width=550,resizable=yes,scrollbars=yes,status=no,toolbar=no,menubar=no,location=no");

}

</script>

传递的值id并且打开一个新的窗口


  2.数据验证问题


  1)验证空值

if(from.textName.value==””){ alert(“must be entered”);return false;}

  注意是双等号,同java语法


  2)验证数字

if(isNaN(checkText1.purchase_quantity.value))

{

alert("請輸入採購量為數字!");

checkText1.purchase_quantity.focus();

return false;

}


  3)验证日期

  注意,最好用onchange 事件在日期输入控件上,当然更好的方式是利用javascript写好的日期输入控件解决,但是多条数据的时候影响速度此种情况下不推荐.

html 输入:

<td><input type="text" name="confirm_date" value="" onChange="return isDate(this)"/></td>


//判斷時間是否正確

function isDate(checktext){

var datetime;

var year,month,day;

var gone,gtwo;

if(Trim(checktext.value)!=""){

datetime=Trim(checktext.value);

if(datetime.length==10){

year=datetime.substring(0,4);

if(isNaN(year)==true){

alert("請輸入日期!格式為(yyyy-mm-dd) \n例(2008-01-01)!");

checktext.focus();

return false;

}

gone=datetime.substring(4,5);

month=datetime.substring(5,7);

if(isNaN(month)==true){

alert("請輸入日期!格式為(yyyy-mm-dd) \n例(2008-01-01)!");

checktext.focus();

return false;

}

gtwo=datetime.substring(7,8);

day=datetime.substring(8,10);

if(isNaN(day)==true){

alert("請輸入日期!格式為(yyyy-mm-dd) \n例(2008-01-01)!");

checktext.focus();

return false;

}

if((gone=="-")&&(gtwo=="-")){

if(month<1||month>12) {

alert("月份必須在01和12之間!");

checktext.focus();

return false;

}

if(day<1||day>31){

alert("日期必須在01和31之間!");

checktext.focus();

return false;

}else{

if(month==2){

if(isLeapYear(year)&&day>29){

alert("二月份日期必須在01到29之間!");

checktext.focus();

return false;

}

if(!isLeapYear(year)&&day>28){

alert("二月份日期必須在01到28之間!");

checktext.focus();

return false;

}

}

if((month==4||month==6||month==9||month==11)&&(day>30)){

alert("在四,六,九,十一月份 \n日期必須在01到30之間!");

checktext.focus();

return false;

}

}

}else{

alert("請輸入日期!格式為(yyyy-mm-dd) \n例(2008-01-01)");

checktext.focus();

return false;

}

}else{

alert("請輸入日期!格式為(yyyy-mm-dd) \n例(2008-01-01)");

checktext.focus();

return false;

}

}else{

return true;

}

return true;

}

这样的话正常用户输入的时候就会验证比较好用.

4)验证字母等

if(document.f1.dep.value!='ab')

// null 是否为空 判断num 数字ab 字母chs 汉字bit 位数

{

alert("Sorry, 請輸入部門名稱為漢字!")

document.f1.dep.focus()

return false

}

}

  不过这种方法好像不好用

  5)按一定格式验证:最好是正则表达式这个是最好用的,而且也验证复杂格式的时候必须的.

  3. 事件触发

MSDN Home > MSDN Library > Web Development > HTML and CSS > HTML and DHTML Reference > Events dhtml 的所有事件

注意以上路径需是通过英文版本的msdn进入!

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:JavaScript中的关键字"VAR"使用祥解

下一篇:vbscript和javascript之间的函数的调用