编程语言
首页 > 编程语言> > 如何使用Javascript和Prototype毫不费力地禁用提交按钮?

如何使用Javascript和Prototype毫不费力地禁用提交按钮?

作者:互联网

所以我找到了this个推荐,但我似乎还不太清楚该怎么做.

这是我最初开始的代码:

   function greySubmits(e) {
      var value = e.srcElement.defaultValue;
      // This doesn't work, but it needs to
      $(e).insert('<input type="hidden" name="commit" value="' + value + '" />');

      // This causes IE to not submit at all
      $$("input[type='submit']").each(function(v) {v.disabled = true;})
   }

   // This works fine
   Event.observe(window, 'load', function() {
     $$("input[type='submit']").each(function(e) {
        Event.observe(e, 'click', greySubmits);
     });
  });

无论如何,我已经很接近了,但是我似乎再也无法做到.

谢谢您的帮助!

更新:对不起,我想我还不太清楚.当某人单击提交按钮时,我想禁用所有提交按钮.但是我确实需要发送Submit按钮的值,以便服务器知道我单击了哪个按钮,因此知道了插入调用. (注意:insert确实是not会创建您调用它的元素的子代.)然后,在禁用提交按钮之后,我需要调用包含提交按钮的表单Submit调用,因为在禁用按钮后IE不会提交.那有意义吗?

解决方法:

您需要完全按照答案说:

“不要在按钮的“ onclick”中禁用按钮,而要保存它,并在表单的onsubmit中进行.”

因此,在greySubmits()中,保留设置隐藏值的行,但删除禁用所有提交按钮的行.

然后在您的在线表单中添加另一个事件处理程序-而不是提交按钮-来禁用该事件处理程序.

 function reallyGreySubmits(e) {
     // This causes IE to not submit at all
     $$("input[type='submit']").each(function(v) {v.disabled = true;})
 }

 Event.observe(window, 'load', function() {
     $$("input[type='submit']").each(function(e) {
        Event.observe(e, 'click', greySubmits);
     });
     $$("form").each(function(e) {
        Event.observe(e, 'submit', reallyGreySubmits);
     });
  });

我使用的另一个选项是不禁用提交,而是在两个元素之间交换可见性.单击时,将提交标记为隐藏,然后使div或其他显示为“已禁用”的元素可见.

标签:javascript,prototypejs
来源: https://codeday.me/bug/20191013/1907173.html