瘋狂

          STANDING ON THE SHOULDERS OF GIANTS
          posts - 481, comments - 486, trackbacks - 0, articles - 1
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          日歷

          <2010年4月>
          28293031123
          45678910
          11121314151617
          18192021222324
          2526272829301
          2345678

          公告

          公眾號:
          QQjava交流群:51374316



          相冊

          搜索

          •  

          積分與排名

          • 積分 - 2844333
          • 排名 - 2

          最新隨筆

          from 表單提交問題

          Posted on 2010-04-13 14:30 瘋狂 閱讀(195) 評論(0)  編輯  收藏 所屬分類: java

          今天在項目中無意中遇到的一個神奇的問題,特此記錄。

          首先我們看看以下代碼,測試頁面可以看這里,頁面的功能和邏輯很簡單。

          這段代碼從邏輯上看沒有任何錯誤和BUG,理論上是可以完全執行的。

          <html>
              <head>IE 測試</head>
          <body>
          <script language="javascript">
          /*
          ======================================
              IE 下 submit 重名測試
              作者:朦朧中的罪惡
              博客:http://be-evil.org
          ======================================
          */
          function dosubmit()
          {
              var theform = document.getElementById('theform');
              theform.submit();
          }
          </script>
              <form method="post" id="theform">
                  <table width="800">
                      <tr>
                          <td><input type="text" value="測試"></td>
                      </tr>
                      <tr>
                          <td><input type="button" name="submit" value="提交" onclick="dosubmit()"></td>
                      </tr>
                  </table>
              </form>
          </body>
          </html>

          如果用Firefox查看這個頁面并點擊提交按鈕,表單會正常提交,但是我們換到IE下面,IE卻會提示“對象不支持此屬性和方法“ 而停止提交的操作。

          這是怎么回事呢?經過我多方的查找資料,發現是提交按鈕的name="submit"的屬性在搗亂。

          此時我們將theform.submit();注釋掉,新起一行輸入alert(theform.submit.value);刷新頁面后再次點擊提交,彈出的窗口上會顯示”提交“兩個字,神奇了!theform.submit居然是提交按鈕而不是theform的方法了!

          為什么會出現這個問題呢,因為在IE下可以通過 表單.表單元素名稱 這樣的方式獲得一個表單下的所有表單元素,但是巧就巧在這里,如果某個表單元素的名稱和表單的方法名重名的話那么IE就會優先將名稱解析為某個表單元素,而不是表單的方法,此時就會出現這個神奇的問題了。


          本文來自CSDN博客,:http://blog.csdn.net/l00109503/archive/2009/03/24/4020135.aspx

           

          主站蜘蛛池模板: 青川县| 盐山县| 华安县| 天峨县| 林州市| 馆陶县| 平武县| 论坛| 搜索| 哈尔滨市| 鹿邑县| 巴中市| 汕头市| 阆中市| 潮州市| 潜山县| 福建省| 涡阳县| 乌拉特中旗| 黄浦区| 宝山区| 海晏县| 囊谦县| 广元市| 朔州市| 玛多县| 赣州市| 若羌县| 永新县| 延川县| 兴城市| 合山市| 绥德县| 西丰县| 伊川县| 安仁县| 黄梅县| 河南省| 玉山县| 望奎县| 沈丘县|