2012-12-03 50 views
0

我正在开发一个JavaScript来检测文本中的链接,并打开一个带有三个按钮“是”,“否”,“取消”的JqueryUI对话框。一切工作正常。当javascript检测到文本中的链接时,会显示对话框。 “否”和“取消”按钮工作正常。我想在用户点击“是”按钮时提交表单,但它不起作用。 这是我的HTML和Javascript代码。JavaScript/jquery不是没有提交表格

<script type="text/javascript"> 

function findUrls() 
{ 
var text = document.forms["myForm"]["text"].value; 

var source = (text || '').toString(); 

var urlArray = []; 

var url; 

var matchArray; 

// Regular expression to find FTP, HTTP(S) and email URLs. 
var regexToken = /\b(http|https)?(:\/\/)?(\S*)\.(\w{2,4})\b/ig; 

// Iterate through any URLs in the text. 
if((regexToken.exec(source)) !== null) 
{ 
    $(document).ready(function(){ 

      $("#dialog").dialog({ 
       autoOpen: false, 
       width: 400, 
       buttons: [ 
        { 
         text: "Yes", 
         click: function() { 
          $("#myForm").submit(); 
         } 
        }, 
        { 
         text: "No", 
         click: function() { 
          $(this).dialog("close"); 
         } 
        }, 
        { 
         text: "Cancel", 
         click: function() { 
          $(this).dialog("close"); 
         } 
        } 
       ] 
      }); 

      $("#dialog").dialog("open"); 

    }); 
} 

} 


function submitform() 
{ 
    document.forms["myForm"].submit(); 
} 
</script> 
<div id="dialog" title="Dialog Title"> 
<p>Tes Test Test.</p> 
<p><a href="javascript: submitform()">Submit</a></p> 
</div> 

<form name="myForm" id="myForm1" action="" onsubmit="return findUrls();"> 
<textarea name="text"></textarea> 
<input type="submit" name="submit" id="dialog-link" value="Check it out." /> 
</form> 
+4

我能说的是:** ** OY ... – Neal

+3

'$(文件)。就绪()'不应该是一个'if'语句中。它应该在脚本的顶层。找到一个好的JavaScript教程,然后找到一个用于jQuery的。 – jrummell

回答

1

对于初学者来说,你onsubmit总是接收undefined值。为了在这种情况下提交表格,findUrls()需要返回true

JavaScript没有void类型,所以每个函数都必须返回一个 的值。缺省值是未定义的,除了构造函数,其中 的默认返回值是this。

http://javascript.crockford.com/survey.html

0

您正在使用的属性名称为ID,而不是使用:

$("#myForm1").submit(); 

或者:

submitform();