zoukankan      html  css  js  c++  java
  • 学习笔记之MVC级联及Ajax操作

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

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

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

     1 public class my_selection
     2     {
     3         [Key]
     4         public int ID { get; set; }
     5         [StringLength(50)]
     6         public string Months { get; set; }
     7         [StringLength(50)]
     8         public string Money { get; set; }
     9 
    10         [StringLength(100)]
    11         public string Remark { get; set; }
    12     }
    View Code

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

     1 //
     2         // GET: /Pay/
     3 
     4         private UBMRegContext db = new UBMRegContext();
     5         public ActionResult Payment(string select_month)
     6         {
     7             //定义一个泛型;
     8             var selectionlist = new List<string>();
     9             var money_values = new List<SelectListItem>();
    10             //从数据库中查询mx;
    11             var mx = from d in db.selectioon orderby d.Months select d.Months;
    12 
    13 
    14             //将从实体查询的数据添加到泛型之内
    15             
    16             selectionlist.AddRange(mx.Distinct());
    17             money_values.Insert(0, new SelectListItem() { Text = "--请选择--", Value = "-1" });
    18 
    19             //生成列表(将加入的泛型添加到页面便于显示)
    20             ViewBag.select_month = new SelectList(selectionlist);
    21             ViewData["Money_value"] = money_values;
    22             return View();
    23 
    24 
    25 
    26         }
    27 
    28         //实现级联
    29        [HttpGet]
    30         public ActionResult ShowSecondDropDownList(string FirstLevel)
    31         {
    32             var moneys = db.selectioon.Where(x => x.Months == FirstLevel);
    33             ViewBag.Money_value = moneys;
    34             return PartialView("Moneyvalue");
    35         }
    View Code

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

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

        <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 = "300px; height:30px" })
    2 @Html.DropDownList("Money_value", (IEnumerable<SelectListItem>)ViewData["Money_value"], new { style = "300px; height:30px;" })

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

    工作的事情要做就要做到最好,做到极致,做到无人能及。
  • 相关阅读:
    如何透过上层div点击下层的元素解决方法
    学习javscript函数笔记(二)
    js栈内存和堆内存的区别
    学习javscript对象笔记(一)
    小程序 给最外层view设置百分之百高度不起作用
    小程序 开发阶段请求网络报 不在以下 request 合法域名列表中
    git安装以及webstorm配置git
    failed to push some refs to 'git@github.com:xxx/xxx.git' 解决方法
    Jquery EasyUI Treegrid按需加载子集
    js时间戳与日期格式的相互转换
  • 原文地址:https://www.cnblogs.com/BarryJames/p/6226684.html
Copyright © 2011-2022 走看看