ホームページ > php教程 > PHP开发 > js选中下拉框项自动提交表单

js选中下拉框项自动提交表单

WBOY
リリース: 2016-06-07 17:23:42
オリジナル
1840 人が閲覧しました

据一位网友反映,他使用WBlog博客程序发现了一个浏览器不兼容的问题,在火狐浏器下添加栏目时,选择模型后,上级栏目没有出现相应的栏目列表!


在解决这个问题之前,先来说一下栏目表单添加的原理。


     在添加栏目的过程中,首先选择模型,如文章、图片、下载等模型,选中下拉菜单的一项后,会触发JS的onChange()事件,自动提交表单,返回该模型相应的栏目。代码如下:

<form action="/Admin/News/insert" method="POST" > 
    <table width="100%" cellspacing="0" style="font-size:12px;"> 
       <tbody> 
            <tr> 
            <td width="100" align="center">请选择模型:</td> 
            <td align="left"> 
           <select name="modelid" id="modelid" onChange="document.all.dosubmit.click()"> 
         <option value="0">模型</option>   
            <volist name="mlist" id="mo"> 
              <if condition="$modelid eq $mo[&#39;modelid&#39;]">  
               <option value="$mo[&#39;modelid&#39;]" selected>{$mo[&#39;model&#39;]} </option> 
              <else />    
                <option value="{$mo[&#39;modelid&#39;]}">{$mo[&#39;model&#39;]}</option>  
              </if> 
              
               </volist>        
                           
        </select>         
      <input  type="submit"  name=&#39;dosubmit&#39; style="display: none;" value="提交" />   
          </td>    
        </tr> 
   </form>
ログイン後にコピー

在整个JS自动触发事件的过程中,起关键作用的代码是onChange="document.all.dosubmit.click()",经测试,这段JS代码在IE浏览器中可以正常执行,但到了火狐浏览器后,却无法执行了。


问题的解决办法
1、经表单

添加一个ID名称,如

2、把document.all.dosubmit.click()修改为document.getElementById('mid').submit()

完成上面的修改后,添加栏目可以在IE、火狐和谷哥浏览器完成!因为我的电脑里就只装了以上三种主流浏览器,其它的有等测试。


      


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート