zoukankan      html  css  js  c++  java
  • form表单原理

    form表单原理

       
    form表单原理
    表单是通过URL地址栏传值的。
    表单的值在php中对应的写法
    form表单原理
    这里要特别注意,如果在php.ini文件中把register_globals = Off关闭的话,那么也能取到值,不过这时要用$title取值 ,这里的title为输入框的name
    很多人对于表单不理解,那是因为表单中隐藏了一个属性,这个属性即为输入框中的输入的东西,这个框就是值,这个是谁的值呢,当然是输入框的名字的值。这个很多书都不提
    form表单原理
    为了减轻php验证表单的压力,要结合javascript的验证
    form表单原理
    上面的表单意为,当提交表单即点onsubmit这个按钮时,它返到CheckPost()这个函数里,当然,这个函数是javascript函数了
    下面javascript的详解。
         function CheckPost(){   //定义一个函数名
       if(myform.user.value==""){  //myform为表单名,user为输入框的名字,valuse为输入框中输入的东西,
               alert("请填写用户名");这时出来提示
               myform.user.focus();点上面的提示后,光标(即焦点)又回到了user这个输入框中
               return false; 同时不让继续,所以是false    
       }
       if(myform.title.value.length<5){  //如果名为myform的表单中名字叫title的输入框的值(即里面填写的东西的值的长度小于5)
           alert("标题不能少于5个字符);  //接上面,这时就弹出一个提示
           myform.title.focus(); //,关闭提示后,焦点又回到了名为title的输入框中,等待用户输入
        }
    }
     
    特别注意:有很多input输入框中,没有value这个值,这种情况是省略了,如果必须写就要填上value="";
    有些是写上了,比如onsubmit的值是value=“提交”就会直接显示,那么很多输入框没有写value=""是为什么呢,因为输入框吗,就是输入的地方,所以不写了,而有些是写的,写的意图是定义默认值。
     
     
     

    URL传值和form表单提交的区别和原理

    form提交的几种方法

    最近研究了下html中,form保单提交的几种方法,现与大家分享一下(注:网上可能已经有好多版本了,这里自己写下来做个总结了,哈!):

    方法一:利用form的onsubmit()函数(经常使用)

    Html代码  收藏代码
    1. <script type="text/javascript">  
    2.     function validateForm(){  
    3.     if(document.reply.title.value == ""){ //通过form名来获取form  
    4.         alert("please input the title!");  
    5.         document.reply.title.focus();  
    6.         return false;  
    7.     }     
    8.     if(document.forms[0].cont.value == ""){ //通过forms数组获取form  
    9.         alert("please input the content!");  
    10.         document.reply.cont.focus();  
    11.         return false;  
    12.     }  
    13.     return true;  
    14.   }  
    15. <form name="reply"  method="post" onsubmit="return validateForm( );">  
    16.         <input type="text" name="title"  size="80" /><br />  
    17.         <textarea name="cont" cols="80" rows="12"></textarea><br />  
    18.         <input type="submit" value="提交" >  
    19. </form>  
    20. 注意:  
    21. 1.onsubmit属性内容一定要有return关键字,否则函数会直接执行,不会返回  
    22. 2.validateForm一定要返回一个boolean类型的返回值  
    23. 3.提交按钮要写成submit类型的  

    方法二:利用input类型为submit组件的onclick()函数

        1.将上面form标签中的onsubmit="return validateForm()"属性,去掉。

        2.为“提交”按钮添加onclick事件,如下:

         <input type="submit" value="提交" onclick="return validateForm();">

    方法三:利用button组件的onclick()函数,手动提交

    Html代码  收藏代码
    1. <script type="text/javascript">  
    2.     function modifyItem() {  
    3.         if (trim(document.getElementById("itemName").value) == "") {  
    4.             alert("物料名称不能为空!");  
    5.             document.getElementById("itemName").focus();  
    6.             return;  
    7.         }   
    8.         with (document.getElementById("itemForm")) {  
    9.             method = "post";  
    10.             action = "item.do?command=modify&pageNo=${itemForm.pageNo}";  
    11.             submit();  
    12.         }  
    13.     }  
    14.     //返回  
    15.     function goBack() {  
    16.         window.self.location = "item.do?command=list&pageNo=${itemForm.pageNo}";  
    17.     }  
    18. </script>  
    19. <form name="itemForm" id="itemForm">  
    20.       <input name="itemNo" type="text"   id="itemNo" value="${ item.itemNo }" >  
    21.       <input name="itemName" type="text"   id="itemName" value="${ item.itemName }" >  
    22.      <input name="btnModify"  type="button" id="btnModify" value=“修改" onclick="modifyItem()">  
    23. </form>  
    24. 注意:  
    25. 1.提交时,设置form的action和methods属性,然后利用form.submit()函数提交。  

     总结:

           1.对form中的组件验证时,前两个使用的是name属性,包括form自身的。

           2.如果提交表单时没有反应,同时确定提交表单部分代码没有问题,请查看提交表单前面的js代码,有时前面js的错误会引发莫名其妙的问题。

     
     
     
  • 相关阅读:
    css的书写位置+元素分类
    选择器
    我的js运动库新
    js的相关距离
    关于小乌龟的使用
    linux 基础
    linux shell快捷操作【超级实用】
    算法面试常见问题【转】
    http://www.cnblogs.com/zhangchaoyang/archive/2012/08/28/2660929.html
    cocos2dx + vs安装使用
  • 原文地址:https://www.cnblogs.com/xiaopihai988/p/4976832.html
Copyright © 2011-2022 走看看