学习笔记之MVC级联及Ajax操作

由于刚转型到MVC,MVC的架构模式很多不是很清楚,比如今天就想做个级联的操作,因为之前的ASP.NET的方式是通过:控件-->添加事件-->后台编写级联事件进行触发,但是这个MVC就不同了。于是乎,开始网上搜寻相关的资料,大部分都是给了一部分,但是不给出详细的说明,练习的话都是半成品;所以为了大家的方便,我把级联的开发过程贴出来,当然大神级的就自动略过了。

第一、数据库数据准备(Mysql)

 

第二、准备Models实体;(对应数据库中的数据)

 

  View Code

 

 第三、准备Controllers,这边名字是PayController;这边主要贴出来两个必备的方法;

  View Code

第四、最为重要的是View的显示页面:当然是刚才创建的Home文件夹下的Views里面;(我第一个卡点就是JS,之前JS实在是不熟练哈哈。检查了之后测试出来是HTML表头的问题,无敌尴尬。)

           这里面有引用到Ajax,笔者之前对于Ajax完全陌生可以说是0基础。研究了将近2小时才研习透彻。这里面有段代码是data: { FirstLevel: FirstLevel }这个参数测试了N多变后台的方法获取的方法值就是null,差点要砸电脑。刚开始第一反应是直接用一个确定的值调试结果还是null,后来又开始怀疑是JS加载有问题,于是调啊调啊,结果还是null(接近奔溃);最后终于参考了别人的方法和官方的说明之后(以后首要地位就是参考官方的文献),{}里面第一个值代表是后台参数的string X是这个X, ":"后面则是触发的传参值,阿西吧。最后经过N多次调试之后终于调通了,感谢祖国。

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<script src= "~/Scripts/jquery-1.8.2.min.js" ></script>
 
<script type= "text/javascript" >
 
     $(document).ready(init);
     function init() {
         $( "select[name='selectioon']" ).change(function () {
             var  FirstLevel = $( this ).val();
             //获取当前的选择的内容传递给方法ShowCityWithSelectedProvince
             if  (FirstLevel !=  "请选择续费时间" )
                 ShowSecondDropDownList(FirstLevel);
             else
                 alert( "Please choose the renewal time before next move!!" );
         });
     }
 
     function ShowSecondDropDownList(FirstLevel) {
         $.ajax({
             url:  "@Url.Action(" ShowSecondViews ", " Pay ")" ,
             type:  "get" ,
             dataType:  "JSON" ,
             data: { FirstLevel: FirstLevel },
             success: function (moneys) {
                 var  ddl = $( "#secondlist" );
                 //删除节点
                 RemoveOption();
                 if  (moneys !=  "" ) {
                     //第一个value是用于后台使用的值,第二个是用于显示的值
                     ddl.append( "<option value='"  + moneys +  "'>$"  + moneys +  "</option>" );
                 }
                 else  {
                     ddl.append( "<option value='-1'>--Auto--</option>" );
                 }
             }
         });
     }
     function RemoveOption() {
         $( "#secondlist option" ).remove();
     }
 
</script>

 

  

 

第五、使用到的Razor语法。级联。

1 @Html.DropDownList("selectioon", (IEnumerable<SelectListItem>)ViewData["select_month"], new { style = "width:300px; height:30px" })
2 @Html.DropDownList("Money_value", (IEnumerable<SelectListItem>)ViewData["Money_value"], new { style = "width:300px; height:30px;" })

至此,花了整整4个小时才彻底理解通了,反正每天都进一步一点就不算浪费今天的时间,加油吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值