日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

MVC3快速搭建Web应用(二)

發(fā)布時(shí)間:2023/12/9 c/c++ 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MVC3快速搭建Web应用(二) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

easyui與mvc的結(jié)合

上一篇文章發(fā)布后,自己又仔細(xì)讀了數(shù)遍,感覺一是文筆太差,二是描述邏輯比較混亂,客觀原因是涉及到東西其實(shí)蠻多的,那三個(gè)步驟不可能在一篇短短的文章中就可以描述清楚。此篇筆者將盡量更加詳盡一些。另外需要說明一點(diǎn)的是,本文默認(rèn)讀者:

  • 熟悉ASP.NET MVC
  • Razor語法
  • 熟悉javascript
  • 實(shí)體框架

Web應(yīng)用不像winform應(yīng)用,要想讓用戶得到更流暢更舒適的體驗(yàn),方法之一就是模擬winform的窗口操作,使用戶在瀏覽器中也能像桌面一樣舒服。在界面框架方面我們有大家最熟悉的jquery ui,有Ext等等,經(jīng)過一系列的篩選,我們最終決定使用easyui,文檔教程例子都比較全面的一個(gè)js ui框架。首先我們來看看用到的js文件

<script src="@Url.Content("~/Scripts/jquery-1.7.2.min.js")" type="text/javascript"></script> jquery主文件<script src="@Url.Content("~/Scripts/jquery.easyui.min.js")" type="text/javascript"></script> easy ui主文件<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script> 校驗(yàn)組件 <script src="@Url.Content("~/Scripts/jquery.form.js")" type="text/javascript"></script> 表單組件<script src="@Url.Content("~/Scripts/easyui-lang-zh_CN.js")" type="text/javascript"></script> easyui的中文化<script src="@Url.Content("~/Scripts/messages_cn.js")" type="text/javascript"></script> 校驗(yàn)組件的中文化

我們把它添加到mvc的Shared/_Layout.cshtml中。這樣我們的項(xiàng)目所有Layout=null的視圖都擁有了easyui支持。

在MVC3中,當(dāng)你右鍵添加一個(gè)控制器時(shí),向?qū)?huì)讓你選擇:

其中模版我們選擇使用實(shí)體框架并生成相關(guān)actions與views,Model選擇你實(shí)體框架中對(duì)應(yīng)的表名(類名),DataContext選擇上下文類

Views引擎選擇Razor,高級(jí)選項(xiàng)里的兩個(gè)勾都去掉,因?yàn)槲覀儾恍枰脙?nèi)置的腳本庫,也不需要選擇layout(不選擇layout,MVC默認(rèn)該view使用Shared/_Layout.cshtml,也就是剛才我們添加js文件link的那個(gè)文件)。

?

確認(rèn)上一篇中你下載的t4模版放進(jìn)了它應(yīng)該存在的地方(最好備份一下原始的),當(dāng)你點(diǎn)擊Add時(shí),vs會(huì)自動(dòng)在Controllers下面添加相應(yīng)的控制器,在views文件夾下添加Create、Edit、Delete、Details、Index五個(gè)文件。下面我們一一查看他們的內(nèi)容:

控制器中,action已經(jīng)自動(dòng)幫你添加完畢

    private BsmisEntities db = new BsmisEntities();//// GET: /User/public ViewResult Index(){return View();}//// GET: /User/Createpublic ActionResult Create(){return View();} //// POST: /User/Create[HttpPost]public ActionResult Create(T_User t_user){JsonResult result = new JsonResult();result.Data = true;try{if (t_user.Enable == null)t_user.Enable = 0;db.T_User.AddObject(t_user);db.SaveChanges();}catch (Exception ee){result.Data = ee.Message;}return result;}//// GET: /User/Edit/5[OutputCache(Location = OutputCacheLocation.None)]public ActionResult Edit(int id){T_User t_user = db.T_User.Single(t => t.UserID == id);ViewBag.DepartmentID = new SelectList(db.T_DepartmentInfo, "DepartmentID", "Code", t_user.DepartmentID);return View(t_user);}//// POST: /User/Edit/5 [HttpPost][OutputCache(Location = OutputCacheLocation.None)]public ActionResult Edit(T_User t_user){JsonResult result = new JsonResult();result.Data = true;try{db.T_User.Attach(t_user);db.ObjectStateManager.ChangeObjectState(t_user, EntityState.Modified);db.SaveChanges();}catch (Exception ee){result.Data = ee.Message;}return result;}//// POST: /User/Delete/5[HttpPost, ActionName("Delete")]public ActionResult DeleteConfirmed(int id){
  
     JsonResult json=new JsonResult();

        json.Data=true;
        try
        {

  T_User t_user = db.T_User.Single(t => t.UserID ==id);db.T_User.DeleteObject(t_user);db.SaveChanges();

        }
        catch(Exception ee)
        {
          json.Data=ee.Message;
        }
        return json;

}/// <summary>/// 數(shù)據(jù)顯示、分頁信息/// </summary>/// <param name="page"></param>/// <param name="rows"></param>/// <returns></returns>public JsonResult List(int page, int rows){var q = from u in db.T_Userjoin d in db.T_DepartmentInfo on u.DepartmentID equals d.DepartmentIDorderby u.UserIDselect new{UserID = u.UserID,UserName = u.UserName,Address = u.Address,Birth = u.Birth,DepartmentID = u.DepartmentID,DepartmentName = d.Name,Enable = u.Enable,Gendar = u.Gendar,IDCardNumber = u.IDCardNumber,LastAccessIP = u.LastAccessIP,LastAccessTime = u.LastAccessTime,LogonTimes = u.LogonTimes,Password = u.Password,PostCode = u.PostCode,RealName = u.RealName,Tel = u.Tel,Province = u.Province,City = u.City,Area = u.Area};var result = q.Skip((page - 1) * rows).Take(rows).ToList();Dictionary<string, object> json = new Dictionary<string, object>();json.Add("total", q.ToList().Count);json.Add("rows", result);return Json(json, JsonRequestBehavior.AllowGet);}

這些action分別對(duì)應(yīng)create、delete、edit、index視圖(detail我們一般情況下不需要它,所以我的模版里沒有寫對(duì)應(yīng)的生成代碼)你可以比較一下它與原生的模版生成的代碼之間的區(qū)別。后期我們還會(huì)在控制器里添加一些譬如檢查名稱是否重名之類的action

[OutputCache(Location = OutputCacheLocation.None)]public JsonResult CheckRealNameExist(string RealName, int UserID){JsonResult result = new JsonResult();result.JsonRequestBehavior = JsonRequestBehavior.AllowGet;result.Data = false;try{if (UserID == 0){if (db.T_User.Any(p => p.RealName == RealName)){return result;}}else{if (db.T_User.Any(p => ((p.UserID != UserID) && (p.RealName == RealName)))){return result;}}}catch (Exception){return result;}result.Data = true;return result;}

返回值一般都是jsonresult。這樣的話,當(dāng)你在瀏覽器中訪問http://localhost:1233/User/CheckRealNameExist?RealName=張三&UserID=0時(shí) 你會(huì)獲得一個(gè)true或false值。是不是跟webservice有點(diǎn)異曲同工?

同樣,在Views文件夾中生成了Create、Edit、Details、Delete、Index五個(gè)文件,其中Details與Delete我們不需要,因?yàn)槲覀兿胧褂酶押玫漠惒絼h除(用戶單擊delete后,頁面不刷新,成功后瀏覽器下方滑出提示,3秒后關(guān)閉,失敗滑出失敗信息,不自動(dòng)關(guān)閉 /利用easyui中的messager組件)。以下是Index中的js:

//刪除function del() {var id = getselectedRow();if (id != undefined) {$.messager.confirm('確認(rèn)', '確定刪除?', function (r) {if (r) {var url = 'User/Delete/' + id;$.post(url, function () {}).success(function () {$.messager.show({title: '提示',msg: '刪除成功',timeout: 3000,showType: 'slide'});$('#dg').datagrid('reload');}).error(function () {$.messager.alert('錯(cuò)誤', '刪除發(fā)生錯(cuò)誤');});}});}}

我們把Details與Delete刪除后只剩下Index、Create、Edit三個(gè)文件,這三個(gè)文件之間的關(guān)系是,Index中包含添加、編輯按鈕,點(diǎn)擊后使用js將對(duì)應(yīng)的actionresult加載到div中,以實(shí)現(xiàn)彈窗新建,編輯的效果。

//新建function c_dlg() {var url = 'User/Create';$('#c_dlg').show();$('#c_dlg').load(url, function () {$(this).dialog({title: '添加',buttons: [{text: '提交',iconCls: 'icon-ok',handler: function () {$('#c_form').submit();}}, {text: '取消',handler: function () {$('#c_dlg').dialog('close');}}]});});}//編輯框function e_dlg() {var id = getselectedRow();if (id != undefined) {var url = 'User/Edit/' + id;$('#e_dlg').show();$('#e_dlg').load(url, function () {$(this).dialog({title: '編輯',buttons: [{text: '提交',iconCls: 'icon-ok',handler: function () {$('#e_form').submit();}}, {text: '取消',handler: function () {$('#e_dlg').dialog('close');}}]});});}}

這里面的c_dlg與e_dlg是index頁面的兩個(gè)Div節(jié)點(diǎn):

<div id="c_dlg" style="width:400px;height:520px;display: none"></div><div id="e_dlg" style="width:400px;height:520px;display: none"></div>

以上的代碼完成將控制器中的action返回的頁面內(nèi)容動(dòng)態(tài)加載到div中,并以彈窗的特效顯示在當(dāng)前(Index)頁面中。效果如圖:

我們來看看Create\Edit視圖的內(nèi)容,首先是js

<script type="text/javascript">$(function () {$('#c_Department').combotree({url: '@Url.Action("GetComboTreeJson","Department")'});$('#c_City').combobox();$('#c_Area').combobox();$('#c_Province').combobox({ url:'CityDic/List/ID/0',onSelect: function (record) {$('#c_City').combobox('reload', 'CityDic/List/ID/' + record.ID).combobox('clear');$('#c_Area').combobox('clear');}});$('#c_City').combobox({onSelect: function (record) {$('#c_Area').combobox('reload', 'CityDic/List/ID/' + record.ID).combobox('clear');}});$('#c_Birth').datebox().datebox('setValue', '@now');$("#c_form").validate({rules: {UserName: {required: true,remote:{url: 'User/CheckNameExist',type: "get",dataType: "json",data: {Name: function () { return $('#c_UserName').val(); },UserID: function () { return 0; }}}},RealName: {required:true,remote: {url: 'User/CheckRealNameExist',type: "get",dataType: "json",data: {RealName: function () { return $('#c_RealName').val(); },UserID: function () { return 0; }}}}},messages: {UserName: {remote: '名稱重復(fù)'}, RealName: { remote: '名稱重復(fù)' }},submitHandler: function (form) {ajaxAdd();}});}); </script>

這部分js將本頁面的控件初始化為對(duì)應(yīng)的下拉框或日期選取框等等,Html為

@using (Html.BeginForm("Create", "User", FormMethod.Post, new { id = "c_form" })) {<fieldset><table class="editForm"><tr><td>@Html.LabelFor(model => model.UserName, "用戶名:")</td><td><input id="c_UserName" name="UserName" style="width: 160px;" required="true" /><span style="color: red">*</span></td></tr><tr><td>@Html.LabelFor(model => model.DepartmentID, "組織機(jī)構(gòu):")</td><td><input id="c_Department" name="DepartmentID" style="width: 160px;" required="true" /><span style="color: red">*</span></td></tr><tr><td>@Html.LabelFor(model => model.Password, "密碼:")</td><td>@Html.PasswordFor(model => model.Password, new { @class = "{required:true,minlength:5}" })<span style="color: red">*</span></td></tr><tr><td><label for="confirm_password">確認(rèn)密碼</label></td><td><input id="confirm_password" name="confirm_password" type="password" class="{required:true,minlength:5,equalTo:'#Password'}" /><span style="color: red">*</span></td></tr><tr><td>@Html.LabelFor(model => model.RealName, "真實(shí)姓名:")</td><td>@Html.TextBoxFor(model => model.RealName, new { @id="c_RealName",@class = "{required:true}" })<span style="color: red">*</span></td></tr><tr><td>@Html.LabelFor(model => model.Gendar, "性別:")</td><td>@Html.RadioButtonFor(model => model.Gendar, "男", new { @id = "radio1", @name = "Gendar", @checked = "checked" })<label for="radio1"></label>@Html.RadioButtonFor(model => model.Gendar, "女", new { @id = "radio2", @name = "Gendar" })<label for="radio2"></label></td></tr><tr><td>@Html.LabelFor(model => model.Birth, "出生日期:")</td><td><input id="c_Birth" required="true" name="Birth" /></td></tr><tr><td>@Html.LabelFor(model => model.IDCardNumber, "身份證號(hào)碼:")</td><td>@Html.EditorFor(model => model.IDCardNumber)</td></tr><tr><td>@Html.LabelFor(model => model.Province, "省份:")</td><td><input name="Province" valuefield="Name" textfield="Name" panelheight="auto" id="c_Province" style="width: 150px"></td></tr><tr><td>@Html.LabelFor(model => model.City, "市:")</td><td><input name="City" valuefield="Name" textfield="Name" panelheight="auto" id="c_City" style="width:150px"></td></tr><tr><td>@Html.LabelFor(model => model.Area, "區(qū)/縣:")</td><td><input name="Area" valuefield="Name" textfield="Name" panelheight="auto" id="c_Area" style="width: 150px"></td></tr><tr><td>@Html.LabelFor(model => model.PostCode, "郵政編碼:")</td><td>@Html.EditorFor(model => model.PostCode)</td></tr><tr><td>@Html.LabelFor(model => model.Address, "地址:")</td><td>@Html.EditorFor(model => model.Address)</td></tr><tr><td>@Html.LabelFor(model => model.Tel, "電話:")</td><td>@Html.EditorFor(model => model.Tel)</td></tr><tr><td>@Html.LabelFor(model => model.Enable, "啟用:")</td><td>@Html.CheckBoxForBool(model=>model.Enable,true,true)</td></tr></table></fieldset> }

編輯視圖中也類似如此。當(dāng)單擊保存按鈕后,執(zhí)行

$('#c_form').submit();

這里我們的客戶端校驗(yàn)在這里:

$("#c_form").validate({rules: {UserName: {required: true,remote:{url: 'User/CheckNameExist',type: "get",dataType: "json",data: {Name: function () { return $('#c_UserName').val(); },UserID: function () { return 0; }}}},RealName: {required:true,remote: {url: 'User/CheckRealNameExist',type: "get",dataType: "json",data: {RealName: function () { return $('#c_RealName').val(); },UserID: function () { return 0; }}}}},messages: {UserName: {remote: '名稱重復(fù)'}, RealName: { remote: '名稱重復(fù)' }},submitHandler: function (form) {ajaxAdd();}});

submitHandler方法提供校驗(yàn)前要做的事情:ajaxAdd()

//異步新建提交function ajaxAdd() {$('#c_form').ajaxSubmit({url: 'User/Create',beforeSubmit: function () {if ($('#c_form').form('validate') != true) {return false;}if ($("#c_form").valid() != true) {return false;}return true;},success: function (data) {if (data == true) {$('#c_dlg').dialog('close');$('#dg').datagrid('reload');$.messager.show({title: '提示',msg: '保存成功',timeout: 2000,showType: 'slide'});} else {$.messager.show({title: '提示',msg: '保存失敗:' + data,timeout: 2000,showType: 'slide'});}}});return false;}

異步提交成功后獲取data,如果是true說明成功了,關(guān)閉“對(duì)話框”,刷新表格,彈出提示。失敗的話將data彈出(一般是失敗原因,由controller中的action返回)。下面是Index中的表格:

<table id="dg" class="easyui-datagrid" toolbar="#toolbar" rownumbers="true" fitColumns="true" singleSelect="true" pagination="true" fit="true"><thead> <tr><th field="DepartmentName" width="80">部門</th><th field="UserName" width="100">用戶名</th><th field="RealName" width="100">真實(shí)姓名</th><th field="Gendar" width="30">性別</th><th field="Birth" width="70" formatter="formatDate">生日</th><th field="Tel" width="50">電話</th><th field="LogonTimes" width="50">登陸次數(shù)</th><th field="LastAccessIP" width="120">最后訪問IP</th><th field="LastAccessTime" width="50">最后訪問時(shí)間</th><th field="Enable" width="50" formatter="formatBool">狀態(tài)</th></tr></thead></table><div id="toolbar">@if (userid != 0 && AuthMgr.HasAuth(userid, "add", 5)){<a href="#" class="easyui-linkbutton" iconCls="icon-add" plain="true" onclick="c_dlg();">添加</a> }@if (userid != 0 && AuthMgr.HasAuth(userid, "edit", 5)){<a href="#" class="easyui-linkbutton" iconCls="icon-edit" plain="true" onclick="e_dlg()" >編輯</a>}</div>

其中@if是用來判斷權(quán)限,如果當(dāng)前登陸用戶擁有add權(quán)限,那么就顯示“添加“按鈕。

今天先寫到這。

轉(zhuǎn)載于:https://www.cnblogs.com/limlee/archive/2012/06/25/rapid_dev_use_mvc_2.html

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的MVC3快速搭建Web应用(二)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。