這是一個腳本,它動態生成文本框和下拉列表。檢查'輸入'和'選擇'jQuery
var ss = $('#ss');
$('#SubGrpId').change(function() {
$('#ss').empty();
$.ajax({
url: '@Url.Action("FillItem", "Item")', // dont hard code your url's
type: "GET",
dataType: "JSON",
data: { MnId: $('#MainGrpId').val(), SbId: $(this).val() }, // pass the selected value
success: function (y) {
alert("Im in");
$.each(y, function (l, u) {
// add the label
var label = u.Name;
var name = 'Field' + l;
var label = $('<label></label>').text(label).attr('for', name);
ss.append(label);
if (u.Options.length==0) {
// There is only one item and its for generating a textbox
var input = $('<input>').attr({ type: 'text', id: name, name: name });
ss.append(input);
} else {
// Its a select
var select = $('<select></select>').attr({ id: name, name: name });
// add each option
$.each(u.Options, function (i, option) {
select.append($('<option></option>').val(option.Value).text(option.Text));
})
ss.append(select);
}
});
var labelAdd = $("<label id='lblId'>").text('Refresh');
ss.append(labelAdd);
},
error: function() {
alert("something wrong");
}
});
});
查看簡要
@using (@Html.BeginForm("Save", "Item"))
{
<div id="ss" class="col-md-6">
</div>
@Html.TextBoxFor(a=>a.ItemName, new { Class = "form-control", placeholder = " Item Name", TextMode = "MultiLine2", onkeyup = "return validateChar(this)", style = "width:175px;height:25px;" })
<input type="submit" value="Save" class="btn btn-success" />
}
現在我想在texboxes文字和的DDL爲「ITEMNAME」文本框,以空格分隔的所選項目的文本。當用戶開始輸入文本框時,文本應該開始綁定到「ItemName」文本框。如果用戶從ddl中選擇一個項目,我們假設「itemThree」,那麼該文本應該被添加到文本框的空格中。這就是我所做的。
$('#ss').on(function() {
if ($('#Field0').is('input')) {
var f1 = $('#Field0').val();
}
else {
var f1 = $('#Field0 option:selected').text();
}
if ($('#Field1').is('input')) {
var f2 = $('#Field1').val();
}
else {
var f2 = $('#Field1 option:selected').text();
}
....
$('#ItemName').val(f1 +" "+ f2 +" "+ f3....);
});
但是這個腳本不起作用。這不會將文本框的文本和ddls的選定項目文本綁定到「ItemName」文本框。 我以這種方式運行上面的腳本,因爲作爲示例id('Field1')可以是文本框或ddl。 所以我檢查了兩種情況。任何人都可以幫我解決這個問題。謝謝!!
你的問題非常難走,你可以重新詞組您的問題? – DelightedD0D
@ DelightedD0D,好的。第一個腳本對此沒有太多必要。考慮最後的腳本。有動態生成的文本框和DDL。它們的順序不相關。如果用戶開始將文本輸入到文本框中它應該開始顯示在「ItemName」文本框中。如果用戶從ddl中選擇一個項目,那麼與該項目相關的文本應該顯示在文本框中。現在它就像這樣「textboxtext ddlitemone ....」 – Isuru
你可以使用**生成的HTML **製作一個jsFiddle嗎? – DelightedD0D