How to get the selected index of a dropdowlist with javascript
- by rui martins
I have a table with several @Html.dropdowlistfor in it.
I was trying to read the selected value of using javascript, but all read is the html generated.
How can I read it??
for (var i = 0; i < oTable.length; i++) {
**userModel.Id = oTable[i][0];**
regionModel.Users.push(userModel);
processModel.Regions.push(regionModel);
userModel = { "Id": "", "Name": ""};
regionModel = { "Id": "", "Name": "", "Users": []};
}
TABLE
<table class="tbl" id="tbl">
<thead>
<tr>
<th>
Region
</th>
<th>
Owner
</th>
</tr>
</thead>
<tbody>
@if (Model != null)
{
foreach (var item in Model.Regions)
{
<tr>
<td>
@Html.DisplayTextFor(i => item.Name)
</td>
<td>
@Html.DropDownListFor(i => item.Users, new SelectList(item.Users, "Id", "Name"))
</td>
</tr>
}
}
</tbody>
CODE
function ProcessSave() {
// Step 1: Read View Data and Create JSON Object
var userModel = { "User": "", "Name": ""};
var regionModel = {"Region" : "","Name": "", "Users": []};
var processModel = { "User": "", "Description": "", "Code": "", "Regions": []};
processModel.Name = $("#Name").val();
processModel.Code = $("#Code").val();
processModel.Description = $("#Description").val();
var oTable = $('.tbl').dataTable().fnGetData();
for (var i = 0; i < oTable.length; i++) {
regionModel.Name = oTable[i][0];
userModel.User = oTable[i][1];
userModel.Name = oTable[i][1];
regionModel.Users.push(userModel);
processModel.Regions.push(regionModel);
userModel = { "Id": "", "Name": ""};
regionModel = { "Name": "", "Users": []};
}
// Step 1: Ends Here
// Set 2: Ajax Post
// Here i have used ajax post for saving/updating information
$.ajax({
url: '/Process/Create',
data: JSON.stringify(processModel),
type: 'POST',
contentType: 'application/json;',
dataType: 'json',
success: function (result) {
if (result.Success == "1") {
window.location.href = "/Process/Index";
}
else {
alert(result.ex);
}
}
});
}
MODELS
namespace TestingTool.ViewModels
{
public partial class ProcessModel
{
public string Name { get; set; }
public string Description { get; set; }
public string Code { get; set; }
public virtual ICollection<RegionModel> Regions { get; set; }
}
}
namespace TestingTool.ViewModels
{
public class RegionModel
{
public int Region { get; set; }
public string Name { get; set; }
public virtual ICollection<UserModel> Users { get; set; }
}
}
namespace TestingTool.ViewModels
{
public class UserModel
{
public int User{ get; set; }
public string Name { get; set; }
}
}