亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

基于MVC3方式實現下拉列表聯動(JQuery)

2019-11-20 22:20:38
字體:
來源:轉載
供稿:網友
上次項目中遇到一個需要多個下拉列表聯動的操作,今天有空將實現方式整理以便以后參考。
要達到的效果是,點擊一個下拉框,則另一個下拉框的值發生對應變化。如:選擇中國,則另個一下拉框里顯示中國各個省份。
傳統的HTML方式比較簡單,實際上基于MVC的實現方式也大同小異。

直接上代碼:
復制代碼 代碼如下:

public class DP_Provice
{
public int proviceID { get; set; }
public string ProviceName { get; set; }
public int ProviceNode { get; set; }
public virtual List<DP_City> citySource { get; set; }
}

public class DP_City
{
public int CityNode { get; set; }
public string CityName { get; set; }
public string ProviceNode { get; set; }
}

對以上涉及到的實體類予以賦值,暫時使用一個靜態類初始化簡單數據:
復制代碼 代碼如下:

public static class DPDataSource
{
public static List<DP_Provice> InitalData()
{
List<DP_Provice> source = new List<DP_Provice>
{
new DP_Provice{ ProviceNode=1, ProviceName="北京", citySource=new List<DP_City>{
new DP_City{
CityNode=11, CityName="北京海淀"
},
new DP_City{
CityNode=12,CityName="北京西城"
}
}},
new DP_Provice{ ProviceNode=2, ProviceName="山東", citySource=new List<DP_City>{
new DP_City{
CityNode=21, CityName="濟南"
},
new DP_City{
CityNode=22,CityName="德州"
}
}},
new DP_Provice{ ProviceNode=3, ProviceName="河北", citySource=new List<DP_City>{
new DP_City{
CityNode=31, CityName="石家莊"
},
new DP_City{
CityNode=32,CityName="衡水"
}
}}
};

return source;
}
}

具體在Controller中的調用,因為使用的JQuery中的AJAX方式,所以返回的結果類型為Json;
復制代碼 代碼如下:

public ActionResult Index()
{
return View("DPShow");
}
List<DP_Provice> source = DPDataSource.InitalData();

public JsonResult GetProvinceSource()
{
if (source == null || source.Count < 0)
{
source = DPDataSource.InitalData();
}
return Json(source, JsonRequestBehavior.AllowGet);
}
public JsonResult GetCitySource(string proviceName)
{
source = DPDataSource.InitalData();
List<DP_City> citySource = new List<DP_City>();
citySource = source.Where(a => a.ProviceNode.ToString().Contains(proviceName)).First().citySource;
return Json(citySource, JsonRequestBehavior.AllowGet);
}

數據準備完畢,此時需要Razor視圖中進行綁定和展示,代碼如下:
復制代碼 代碼如下:

@model MvcApplication.Models.DP_Provice
@{
ViewBag.Title = "DPShow";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<script type="text/javascript">
$(function myfunction() {
GetPlant();
//初始化省份數據
$("#ddlProvince").change(function ff() { //設置當省份下拉列表發生變化時,更新城市數據列表
GetCity();
});
});

function GetPlant() {
$("#ddlProvince").empty();
var url = "/Dropdown/GetProvinceSource/";
$.getJSON(url, function (data) {
$.each(data, function (i, item) {
$("<option></option>")
.val(item["ProviceNode"])
.text(item["ProviceName"])
.appendTo($("#ddlProvince"));
});
GetCity();
});
}
function GetCity() {
$("#ddlCity").empty();
var temp=$("#ddlProvince").val();
var url ="@Url.Action("GetCitySource", "Dropdown")" ;
//使用MVC3中Url.Action 方法參數依次為:aciton ; controller ; area ;

$.getJSON(url,{"proviceName":temp}, function (data) {
//中間需要用到參數 所以采用在getJSON方法中實現
$.each(data, function (i, item) {
$("<option></option>")
.val(item["CityNode"])
.text(item["CityName"])
.appendTo($("#ddlCity"));
});
});
}
</script>
<! DOCTYPE html />
<h2>
下拉列表聯動</h2>
<table>
<tr>
<td>
<select id="ddlProvince" />
</td>
<td>
<select id="ddlCity" />
</td>
</tr>
</table>

說明:
一般來講,采用MVC實現下拉列表綁定可以有多種方式,主要是數據綁定方式可以使用JQuery中的Ajax 方式,同時也可以使用自定義的基于MVC 的 Url.Acion 方式,個人建議使用基于MVC 的 Url.Acion。
一來是支持方式比較靈活,如果中間涉及到數據類型復雜,可以自定義,實現數據封裝;
二來是JQuery 中URL在傳遞參數時需要格式化,否則將無法找到指定的Action。
如有大家對上述說法有異議或者更好的實現方案,請給予指正或說明,謝謝。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久色精品视频| 欧美精品免费播放| 欧美性黄网官网| 高潮白浆女日韩av免费看| 91免费看片网站| 亚洲高清福利视频| 日韩精品999| 欧美亚洲成人精品| 欧美成人精品不卡视频在线观看| 日韩欧美一区二区三区久久| 这里只有精品视频在线| 日韩美女福利视频| 亚洲美女久久久| 91亚洲va在线va天堂va国| 久久成人人人人精品欧| 国模私拍视频一区| 久久99精品久久久久久噜噜| 亚洲第一视频网| 成人在线国产精品| 茄子视频成人在线| 国产成人亚洲综合| 亚洲精品自拍视频| 这里只有精品丝袜| 日韩视频免费看| 欧美亚洲国产视频小说| 国产在线不卡精品| 亚洲一区二区日本| 久久这里只有精品视频首页| 亚洲国产精品字幕| 国产精品18久久久久久首页狼| 欧美黑人xxx| 久久99久久99精品中文字幕| 亚洲国产精彩中文乱码av| 日韩av快播网址| 国产精品视频一区二区高潮| 国产精品视频999| 亚洲精品狠狠操| 亚洲国产欧美一区二区三区同亚洲| 国产精品久久久| 夜夜嗨av色综合久久久综合网| 国产亚洲一区精品| 啊v视频在线一区二区三区| 国产精品美腿一区在线看| xxav国产精品美女主播| 黑人与娇小精品av专区| 国产在线观看91精品一区| 热久久这里只有精品| 精品亚洲精品福利线在观看| 欧美人交a欧美精品| 国产精品久久久久久av福利| 久久久久这里只有精品| 日韩欧美在线网址| 国产伦精品一区二区三区精品视频| 68精品国产免费久久久久久婷婷| 黄色一区二区三区| 亚洲片在线观看| 国产综合在线观看视频| 日本免费久久高清视频| 日本欧美一级片| 这里只有精品视频| 日本精品va在线观看| 国产精品久久久久久超碰| 国产精品99免视看9| 7777免费精品视频| 国产精品91一区| 欧美激情欧美激情| 欧美裸体xxxx极品少妇| 亚洲欧美成人一区二区在线电影| 久久久久这里只有精品| 国产精品久久久精品| 成人有码视频在线播放| 成人激情视频在线播放| 亚洲天堂av高清| 久久精品电影一区二区| 亚洲色图50p| 亚洲精品久久久久久久久| 日韩欧美在线视频| 亚洲精品狠狠操| 亚洲www在线观看| 中文字幕亚洲欧美日韩2019| 久久免费在线观看| 国产91九色视频| 深夜福利国产精品| 久久久久久噜噜噜久久久精品| 这里只有精品丝袜| 国产美女直播视频一区| 国产视频福利一区| 亚州精品天堂中文字幕| 亚洲成人激情在线观看| 国产欧美日韩高清| 日韩欧美在线视频免费观看| 亚洲国产高清福利视频| 揄拍成人国产精品视频| 日韩视频在线观看免费| 国产日产欧美精品| 性欧美长视频免费观看不卡| 51精品在线观看| 欧美精品免费在线观看| 亚洲午夜小视频| 久久天天躁日日躁| 欧美成年人在线观看| 中日韩美女免费视频网站在线观看| 在线观看国产欧美| 91精品视频免费看| 亚洲另类xxxx| 精品视频在线播放色网色视频| 疯狂做受xxxx高潮欧美日本| 国产精品一区二区三区久久| 色噜噜狠狠狠综合曰曰曰88av| 日韩精品欧美激情| 国产欧美一区二区三区视频| 日本欧美在线视频| 成人国产精品一区二区| 日韩av在线免播放器| 欧美日韩第一页| 亚洲一区www| 欧美大片在线影院| 欧美大尺度在线观看| 国产日产久久高清欧美一区| 精品欧美一区二区三区| 亚洲国产精品成人一区二区| 亚洲欧美日韩国产成人| 国产一区二区在线免费视频| 亚洲香蕉伊综合在人在线视看| 国产精品久久久久久久久久久久久久| 国产一区二中文字幕在线看| 国产成人综合一区二区三区| 尤物九九久久国产精品的特点| 日韩精品极品在线观看| 亚洲欧美在线看| 91香蕉国产在线观看| 久久久久久久一区二区三区| 欧美日韩福利视频| 国产男女猛烈无遮挡91| 国产美女搞久久| 日韩在线观看av| 精品视频在线播放色网色视频| 992tv成人免费视频| 欧美与黑人午夜性猛交久久久| 国产精品久久久av久久久| 国产精品美女av| 欧美日韩精品在线播放| 国产日本欧美在线观看| 亚洲电影免费观看| 欧美性xxxx在线播放| 亚洲欧洲国产伦综合| 国模精品一区二区三区色天香| 亚洲成人黄色网| 国产欧美一区二区三区视频| 国产精品入口福利| 午夜剧场成人观在线视频免费观看| 中文字幕日韩欧美在线| 性色av一区二区三区红粉影视| 精品国产91久久久久久| 国产久一一精品| 欧美日韩国产激情| 亚洲午夜性刺激影院| 综合欧美国产视频二区| 日本一区二三区好的精华液| 国产亚洲精品综合一区91| 国产精品高潮在线| 国产精品网红直播| 亚洲欧美精品一区二区| 国语对白做受69|