[英]Changing Jquery UI Dialog Button to a form submit button
我正在嘗試使用Jquery-ui對話框按鈕之一作為表單提交按鈕。 我想使用Submit按鈕,因為它觸發了HTML5的表單驗證,而form.submit()不會。 目前,我正在使用一個隱藏的提交按鈕,並使用一個點擊觸發器來提交表單,但是如果我能使它正常工作,它將變得更加整潔。
我可以毫無疑問地將按鈕更改為類型submit
,但似乎無法將form
添加到屬性中
由於按鈕不在表單標簽內,因此無法正確提交
期望:
<button type="submit" form='createUser' id="submit-button" everythingelse="works" foo="bar" class="ui-button ui-corner-all ui-widget">submit</button>
結果:
<button type="submit" id="submit-button" everythingelse="works" foo="bar" class="ui-button ui-corner-all ui-widget">submit</button>
我可以為按鈕設置各種隨機的東西,但是由於某種原因它不會采取form
,我只是不明白為什么。
我讀了博客在這里 ,它似乎form
使用在以前版本的jQuery的UI的工作,但它不工作了。
測試代碼:
jsfiddle鏈接: https ://jsfiddle.net/s5cjk3wr/
的HTML:
<div id="dialog-form" title="Create new user">
<form id='createUser'>
<fieldset>
<label for="name">Name</label>
<input type="text" name="name" id="name" value="Jane Smith" class="text ui-widget-content ui-corner-all">
<label for="email">Email</label>
<input type="text" name="email" id="email" value="jane@smith.com" class="text ui-widget-content ui-corner-all">
<label for="password">Password</label>
<input type="password" name="password" id="password" value="xxxxxxx" class="text ui-widget-content ui-corner-all">
<input type="submit" tabindex="-1" style="position:absolute; top:-1000px">
</fieldset>
</form>
</div>
<button id="create-user">Create new user</button>
javascript:
$( function() {
dialog = $( "#dialog-form" ).dialog({
autoOpen: false,
height: 400,
width: 350,
modal: true,
buttons: {
"Create an account": {
text:"submit",
id: "submit-button",
type: "submit",
form: "createUser",
everythingElse: "works",
foo: "bar"
},
Cancel: function() {
dialog.dialog( "close" );
}
}
});
form = dialog.find( "form" ).on( "submit", function( event ) {
event.preventDefault();
});
$( "#create-user" ).button().on( "click", function() {
dialog.dialog( "open" );
});
});
的CSS
label, input { display:block; }
input.text { margin-bottom:12px; width:95%; padding: .4em; }
fieldset { padding:0; border:0; margin-top:25px; }
h1 { font-size: 1.2em; margin: .6em 0; }
div#users-contain { width: 350px; margin: 20px 0; }
div#users-contain table { margin: 1em 0; border-collapse: collapse; width: 100%; }
div#users-contain table td, div#users-contain table th { border: 1px solid #eee; padding: .6em 10px; text-align: left; }
.ui-dialog .ui-state-error { padding: .3em; }
.validateTips { border: 1px solid transparent; padding: 0.3em; }
為什么不附加單擊時將提交表單的功能,就像這樣。
buttons: {
"Create an account": function(){$('#createUser').submit()},
Cancel: function() {
dialog.dialog( "close" );
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.