從零開始,搭建博客系統MVC5+EF6搭建框架(4)下,先後檯布局實現、發佈博客以及展現。

1、博客系統進度回顧javascript

   目前已經完成了,前臺展現,以及後臺發佈的功能,最近都在作這個,其實我在國慶的時候就能夠弄完的,可是天天本身弄,忽然最後國慶2天,連電腦都不想碰,因此就一直拖着,上一篇寫了前端實現用到的一些WebUI框架以及一些系統中用到的js插件,其實寫了這麼久,仍是第一次,有人留言,不要爛尾的,感受仍是有點點價值的,至少有人關注。css

  廢話很少說,如今開始上代碼。html

2、博客系統後臺佈局實現前端

  2.1.這裏所用的是MVC的佈局頁來實現的,後臺主要分爲三部分:導航、菜單、主要內容html5

image

代碼實現:java

   這裏把後臺單獨放在一個區域裏面,因此我這裏創建一個admin的區域jquery

image

在佈局頁_Layout.cshtml引入公共的一些css文件以及js文件git

image

image

佈局頁代碼_Layout.cshtml:github

  1 <!DOCTYPE html>
  2 <html>
  3 <head>
  4     <meta charset="utf-8" />
  5     <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6     <title>@ViewBag.Title - 博客系統後臺管理</title>
  7     <link href="~/Content/CSS/zui.css" rel="stylesheet" />
  8     <link href="~/Content/CSS/zui-theme.css" rel="stylesheet" />
  9     <link href="//cdn.bootcss.com/font-awesome/4.6.3/css/font-awesome.min.css" rel="stylesheet">
 10     <link href="~/Content/lib/metisMenu/metisMenu.css" rel="stylesheet" />
 11     <link href="~/Content/CSS/index.css" rel="stylesheet" />
 12     @RenderSection("stylesheet", required: false)
 13     <script src="~/Content/JS/jquery-1.12.4.min.js"></script>
 14     <script src="~/Content/JS/zui.js"></script>
 15     <script src="~/Content/lib/metisMenu/metisMenu.js"></script>
 16     <script src="~/Content/JS/index.js"></script>
 17 
 18     <!--[if lt IE 9]>
 19     <script src="http://libs.useso.com/js/html5shiv/3.7/html5shiv.min.js"></script>
 20     <script src="http://libs.useso.com/js/respond.js/1.4.2/respond.min.js"></script>
 21     <script src="lib/ieonly/excanvas.js"></script>
 22     <![endif]-->
 23 
 24 </head>
 25 <body>
 26     <!--header-->
 27     <header>
 28         <div class="navbar navbar-inverse " role="navigation">
 29             <div class="navbar-header">
 30                 <!--移動設備上的導航切換按鈕-->
 31                 <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse-example">
 32                     <span class="sr-only">切換導航</span>
 33                     <span class="icon-bar"></span>
 34                     <span class="icon-bar"></span>
 35                     <span class="icon-bar"></span>
 36                 </button>
 37                 <!--品牌名稱或logo-->
 38                 <a class="navbar-brand">系統後臺</a>
 39             </div>
 40             <div class="collapse navbar-collapse navbar-collapse-example">
 41                 <ul class="nav navbar-nav navbar-right">
 42                     <li><a><i class="icon icon-user"></i>&nbsp;&nbsp;您好,admin</a></li>
 43                     <li><a><i class="icon icon-exchange"></i>&nbsp;&nbsp;隱藏菜單</a></li>
 44                     <li><a href="/admin/Home"><i class="icon icon-home"></i>&nbsp;&nbsp;首頁</a></li>
 45                     <li><a><i class="icon icon-question-sign"></i>&nbsp;&nbsp;幫助</a></li>
 46                     <li><a><i class="icon icon-off"></i>&nbsp;&nbsp;退出</a></li>
 47                 </ul>
 48             </div>
 49         </div>
 50     </header>
 51     <!--header end-->
 52     <!--content-->
 53     <div class="clearfix">
 54         @Html.Partial("_sidebar")
 55         <div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 rightmain">
 56             <div class="col-sm-12  col-md-12  rightcontent">
 57                 @RenderBody()
 58             </div>
 59         </div>
 60     </div>
 61     <!--content end-->
 62     <!--footer-->
 63     <footer class="col-md-12 footer footerstyle">
 64         <p>&copy; @DateTime.Now.Year - 個人博客系統</p>
 65     </footer>
 66     <!--footer end-->
 67 
 68     <script src="~/Scripts/jquery.validate.js"></script>
 69     <script src="~/Scripts/jquery.validate.unobtrusive.js"></script>
 70     <script src="~/Scripts/jquery.unobtrusive-ajax.js"></script>
 71     @RenderSection("scripts", required: false)
 72 </body>
 73 </html>
View Code

菜單部分頁_sidebar.cshtml代碼web

  1 @{
  2     string url = Request.Url.ToString().ToLower();
  3 }
  4 @if (url.Contains("home"))
  5 {
  6     <aside class="col-sm-3 col-md-2 sidebar">
  7         <nav class="sidebar-nav">
  8             <ul class="metismenu" id="menu">
  9                 <li class="active">
 10                     <a href="#" aria-expanded="true">
 11                         <i class="icon icon-github"></i>
 12                         系通通計<i class="fa arrow fa-fw"></i>
 13                     </a>
 14                     <ul aria-expanded="true">
 15                         <li>
 16                             <a href="/admin/statistics/visitor">
 17                                 <i class="icon icon-list"></i>
 18                                 訪問統計
 19                             </a>
 20                         </li>
 21                         <li>
 22                             <a href="/admin/statistics/usesr">
 23                                 <i class="icon icon-github"></i>
 24                                 用戶統計
 25                             </a>
 26                         </li>
 27                     </ul>
 28                 </li>
 29                 <li>
 30                     <a href="#" aria-expanded="false">博客管理<i class="fa arrow fa-fw"></i></a>
 31                     <ul aria-expanded="false">
 32                         <li><a href="/admin/BlogArticle/Index">博客列表</a></li>
 33                         <li><a href="/admin/BlogArticle/Add">發佈博客</a></li>
 34                     </ul>
 35                 </li>
 36                 <li>
 37                     <a href="#" aria-expanded="false">廣告管理<i class="fa arrow fa-fw"></i></a>
 38                     <ul aria-expanded="false">
 39                         <li><a href="@Url.Action("index", "Advertisement")">輪播圖管理</a></li>
 40                     </ul>
 41                 </li>
 42                 <li>
 43                     <a href="#" aria-expanded="false">用戶管理<i class="fa arrow fa-fw"></i></a>
 44                     <ul aria-expanded="false">
 45                         <li><a href="#">修改信息</a></li>
 46                         <li><a href="#">修改密碼</a></li>
 47                         <li>
 48                             <a href="#" aria-expanded="false">用戶信息管理<span class="fa plus-times"></span></a>
 49                             <ul aria-expanded="false">
 50                                 <li><a href="#">修改信息</a></li>
 51                                 <li><a href="#">修改密碼</a></li>
 52                             </ul>
 53                         </li>
 54                     </ul>
 55                 </li>
 56                 <li>
 57                     <a href="#" aria-expanded="false">權限管理<i class="fa arrow fa-fw"></i></a>
 58                     <ul aria-expanded="false">
 59                         <li><a href="#">用戶受權</a></li>
 60                         <li><a href="#">用戶組管理</a></li>
 61                         <li><a href="#">用戶組受權</a></li>
 62                     </ul>
 63                 </li>
 64                 <li>
 65                     <a href="#" aria-expanded="false">日誌管理<i class="fa arrow fa-fw"></i></a>
 66                     <ul aria-expanded="false">
 67                         <li><a href="#">用戶日誌</a></li>
 68                         <li><a href="#">系統日誌</a></li>
 69                     </ul>
 70                 </li>
 71             </ul>
 72         </nav>
 73     </aside>
 74 }
 75 else if (url.Contains("blogarticle"))
 76 {
 77     <aside class="col-sm-3 col-md-2 sidebar">
 78         <nav class="sidebar-nav">
 79             <ul class="metismenu" id="menu">
 80                 <li>
 81                     <a href="#" aria-expanded="true">
 82                         <i class="icon icon-github"></i>
 83                         系通通計<i class="fa arrow fa-fw"></i>
 84                     </a>
 85                     <ul aria-expanded="true">
 86                         <li>
 87                             <a href="/admin/statistics/visitor">
 88                                 <i class="icon icon-list"></i>
 89                                 訪問統計
 90                             </a>
 91                         </li>
 92                         <li>
 93                             <a href="/admin/statistics/usesr">
 94                                 <i class="icon icon-github"></i>
 95                                 用戶統計
 96                             </a>
 97                         </li>
 98                     </ul>
 99                 </li>
100                 <li class="active">
101                     <a href="#" aria-expanded="false">博客管理<i class="fa arrow fa-fw"></i></a>
102                     <ul aria-expanded="false">
103                         <li><a href="/admin/BlogArticle/Index">博客列表</a></li>
104                         <li><a href="/admin/BlogArticle/Add">發佈博客</a></li>
105                     </ul>
106                 </li>
107                 <li>
108                     <a href="#" aria-expanded="false">廣告管理<i class="fa arrow fa-fw"></i></a>
109                     <ul aria-expanded="false">
110                         <li><a href="@Url.Action("index", "Advertisement")">輪播圖管理</a></li>
111                     </ul>
112                 </li>
113                 <li>
114                     <a href="#" aria-expanded="false">用戶管理<i class="fa arrow fa-fw"></i></a>
115                     <ul aria-expanded="false">
116                         <li><a href="#">修改信息</a></li>
117                         <li><a href="#">修改密碼</a></li>
118                         <li>
119                             <a href="#" aria-expanded="false">用戶信息管理<span class="fa plus-times"></span></a>
120                             <ul aria-expanded="false">
121                                 <li><a href="#">修改信息</a></li>
122                                 <li><a href="#">修改密碼</a></li>
123                             </ul>
124                         </li>
125                     </ul>
126                 </li>
127                 <li>
128                     <a href="#" aria-expanded="false">權限管理<i class="fa arrow fa-fw"></i></a>
129                     <ul aria-expanded="false">
130                         <li><a href="#">用戶受權</a></li>
131                         <li><a href="#">用戶組管理</a></li>
132                         <li><a href="#">用戶組受權</a></li>
133                     </ul>
134                 </li>
135                 <li>
136                     <a href="#" aria-expanded="false">日誌管理<i class="fa arrow fa-fw"></i></a>
137                     <ul aria-expanded="false">
138                         <li><a href="#">用戶日誌</a></li>
139                         <li><a href="#">系統日誌</a></li>
140                     </ul>
141                 </li>
142             </ul>
143         </nav>
144     </aside>
145 }
146 else if (url.Contains("advertisement"))
147 {
148     <aside class="col-sm-3 col-md-2 sidebar">
149         <nav class="sidebar-nav">
150             <ul class="metismenu" id="menu">
151                 <li>
152                     <a href="#" aria-expanded="true">
153                         <i class="icon icon-github"></i>
154                         系通通計<i class="fa arrow fa-fw"></i>
155                     </a>
156                     <ul aria-expanded="true">
157                         <li>
158                             <a href="/admin/statistics/visitor">
159                                 <i class="icon icon-list"></i>
160                                 訪問統計
161                             </a>
162                         </li>
163                         <li>
164                             <a href="/admin/statistics/usesr">
165                                 <i class="icon icon-github"></i>
166                                 用戶統計
167                             </a>
168                         </li>
169                     </ul>
170                 </li>
171                 <li >
172                     <a href="#" aria-expanded="false">博客管理<i class="fa arrow fa-fw"></i></a>
173                     <ul aria-expanded="false">
174                         <li><a href="/admin/BlogArticle/Index">博客列表</a></li>
175                         <li><a href="/admin/BlogArticle/Add">發佈博客</a></li>
176                     </ul>
177                 </li>
178                 <li class="active">
179                     <a href="#" aria-expanded="false">廣告管理<i class="fa arrow fa-fw"></i></a>
180                     <ul aria-expanded="false">
181                         <li><a href="@Url.Action("index", "Advertisement")">輪播圖管理</a></li>
182                     </ul>
183                 </li>
184                 <li>
185                     <a href="#" aria-expanded="false">用戶管理<i class="fa arrow fa-fw"></i></a>
186                     <ul aria-expanded="false">
187                         <li><a href="#">修改信息</a></li>
188                         <li><a href="#">修改密碼</a></li>
189                         <li>
190                             <a href="#" aria-expanded="false">用戶信息管理<span class="fa plus-times"></span></a>
191                             <ul aria-expanded="false">
192                                 <li><a href="#">修改信息</a></li>
193                                 <li><a href="#">修改密碼</a></li>
194                             </ul>
195                         </li>
196                     </ul>
197                 </li>
198                 <li>
199                     <a href="#" aria-expanded="false">權限管理<i class="fa arrow fa-fw"></i></a>
200                     <ul aria-expanded="false">
201                         <li><a href="#">用戶受權</a></li>
202                         <li><a href="#">用戶組管理</a></li>
203                         <li><a href="#">用戶組受權</a></li>
204                     </ul>
205                 </li>
206                 <li>
207                     <a href="#" aria-expanded="false">日誌管理<i class="fa arrow fa-fw"></i></a>
208                     <ul aria-expanded="false">
209                         <li><a href="#">用戶日誌</a></li>
210                         <li><a href="#">系統日誌</a></li>
211                     </ul>
212                 </li>
213             </ul>
214         </nav>
215     </aside>
216 }
View Code

其實我這個菜單選中的效果作的很垃圾,我本身都以爲不要,可是目前我也只能想到這個方法,由於每次加載一個嵌套的頁面就會重新去加載一次佈局頁_Layout.cshtml的內容,我這個菜單是有一個active選中的樣式的,這個是菜單插件裏面已經寫好了,這裏遇到的問題就是每次刷新都會把頁面選中效果設置到默認的菜單上,假如點擊了發佈博客菜單應該顯示博客管理這個菜單內容,可是重新加載的時候就會回到默認的系通通計菜單上,因此這裏就用地址路徑來判斷應該顯示那個菜單,方法真的很笨,見諒,各位。

2.2博客信息添加功能實現

   在model層的Models文件建立一個BlogArticle類,而後在建立一個文件VeiwModels,Models文件夾裏面的類是用來生成數據庫對應的表,而VeiwModels文件夾裏面對應的類是用來在view視圖頁面展現數據用的,當你一個表字段不少不須要全部數據都展現,或者要作一些處理計算的類,這樣就須要一個VeiwModels類來分離。

BlogArticle類:

  1 namespace Wchl.WMBlog.Model.Models
  2 {
  3     /// <summary>博客文章
  4     /// 
  5     /// </summary
  6     public class BlogArticle
  7     {
  8         /// <summary>
  9         /// 
 10         /// </summary>
 11         public int bID { get; set; }
 12         /// <summary>建立人
 13         /// 
 14         /// </summary>
 15         public string bsubmitter { get; set; }
 16 
 17         /// <summary>博客標題
 18         /// 
 19         /// </summary>
 20         public string btitle { get; set; }
 21 
 22         /// <summary>類別
 23         /// 
 24         /// </summary>
 25         public string bcategory { get; set; }
 26 
 27         /// <summary>內容
 28         /// 
 29         /// </summary>
 30         public string bcontent { get; set; }
 31 
 32         /// <summary>
 33         /// 訪問量
 34         /// </summary>
 35         public int btraffic { get; set; }
 36 
 37         /// <summary>
 38         /// 評論數量
 39         /// </summary>
 40         public int bcommentNum { get; set; }
 41 
 42         /// <summary> 修改時間
 43         /// 
 44         /// </summary>
 45         public DateTime bUpdateTime { get; set; }
 46 
 47         /// <summary>
 48         /// 建立時間
 49         /// </summary>
 50         public System.DateTime bCreateTime { get; set; }
 51         /// <summary>備註
 52         /// 
 53         /// </summary>
 54         public string bRemark { get; set; }
 55     }
 56 }
View Code

BlogViewModels類:

  1 namespace Wchl.WMBlog.Model.VeiwModels
  2 {
  3     /// <summary>
  4     /// 博客信息展現類
  5     /// </summary>
  6     public class BlogViewModels
  7     {
  8         /// <summary>
  9         /// 
 10         /// </summary>
 11         public int bID { get; set; }
 12         /// <summary>建立人
 13         /// 
 14         /// </summary>
 15         public string bsubmitter { get; set; }
 16 
 17         /// <summary>博客標題
 18         /// 
 19         /// </summary>
 20         public string btitle { get; set; }
 21 
 22         /// <summary>摘要
 23         /// 
 24         /// </summary>
 25         public string digest { get; set; }
 26 
 27         /// <summary>
 28         /// 上一篇
 29         /// </summary>
 30         public string previous { get; set; }
 31 
 32         /// <summary>
 33         /// 上一篇id
 34         /// </summary>
 35         public int previousID { get; set; }
 36 
 37         /// <summary>
 38         /// 下一篇
 39         /// </summary>
 40         public string next { get; set; }
 41 
 42         /// <summary>
 43         /// 下一篇id
 44         /// </summary>
 45         public int nextID { get; set; }
 46 
 47         /// <summary>類別
 48         /// 
 49         /// </summary>
 50         public string bcategory { get; set; }
 51 
 52         /// <summary>內容
 53         /// 
 54         /// </summary>
 55         public string bcontent { get; set; }
 56 
 57         /// <summary>
 58         /// 訪問量
 59         /// </summary>
 60         public int btraffic { get; set; }
 61 
 62         /// <summary>
 63         /// 評論數量
 64         /// </summary>
 65         public int bcommentNum { get; set; }
 66 
 67         /// <summary> 修改時間
 68         /// 
 69         /// </summary>
 70         public DateTime bUpdateTime { get; set; }
 71 
 72         /// <summary>
 73         /// 建立時間
 74         /// </summary>
 75         public System.DateTime bCreateTime { get; set; }
 76         /// <summary>備註
 77         /// 
 78         /// </summary>
 79         public string bRemark { get; set; }
 80     }
 81 }
View Code

在maps文件夾中添加相應的約束

BlogArticleMap類:

  1 namespace Wchl.WMBlog.Model.Maps
  2 {
  3     public class BlogArticleMap: EntityTypeConfiguration<BlogArticle>
  4     {
  5         public BlogArticleMap()
  6         {
  7             this.HasKey(p => p.bID);
  8             this.Property(p => p.btitle).HasMaxLength(256);
  9             this.Property(p => p.bsubmitter).HasMaxLength(60);
 10             this.Property(p => p.bcontent).HasColumnType("Text").IsMaxLength();
 11         }
 12     }
 13 }
View Code

而後在控制檯使用更新數據庫命令:update database -force,必定要選擇model層

image

建立好了表,而後就是在倉儲層以及業務層建立相應的接口和實現類

IBlogArticleRepository類:

  1 namespace Wchl.WMBlog.IRepository
  2 {
  3     public interface IBlogArticleRepository:IBaseRepository<BlogArticle>
  4     {
  5     }
  6 }
  7 
View Code

BlogArticleRepository類:

  1 namespace Wchl.WMBlog.Repository
  2 {
  3     public class BlogArticleRepository: BaseRepository<BlogArticle>, IBlogArticleRepository
  4     {
  5     }
  6 }
View Code

IBlogArticleServices類:

  1 namespace Wchl.WMBlog.IServices
  2 {
  3     public interface IBlogArticleServices: IBaseServices<BlogArticle>
  4     {
  5         /// <summary>
  6         /// 獲取視圖博客詳情信息
  7         /// </summary>
  8         /// <param name="id"></param>
  9         /// <returns></returns>
 10         BlogViewModels getBlogDetails(int id);
 11     }
 12 }
View Code

BlogArticleServices類:

  1 namespace Wchl.WMBlog.Services
  2 {
  3     public class BlogArticleServices: BaseServices<BlogArticle>, IBlogArticleServices
  4     {
  5         IBlogArticleRepository dal;
  6 
  7         public BlogArticleServices(IBlogArticleRepository dal)
  8         {
  9             this.dal = dal;
 10             base.baseDal = dal;
 11         }
 12 
 13         /// <summary>
 14         /// 獲取視圖博客詳情信息
 15         /// </summary>
 16         /// <param name="id"></param>
 17         /// <returns></returns>
 18         public BlogViewModels getBlogDetails(int id)
 19         {
 20             BlogArticle blogArticle = dal.QueryWhere(a => a.bID == id).FirstOrDefault();
 21             BlogArticle nextblog= dal.QueryWhere(a => a.bID == id-1).FirstOrDefault();
 22             BlogArticle prevblog = dal.QueryWhere(a => a.bID == id+1).FirstOrDefault();
 23             blogArticle.btraffic += 1;
 24             dal.Edit(blogArticle, new string[] { "btraffic" });
 25             dal.SaverChanges();
 26             //AutoMapper自動映射
 27             Mapper.Initialize(cfg => cfg.CreateMap<BlogArticle, BlogViewModels>());
 28             BlogViewModels models = Mapper.Map<BlogArticle, BlogViewModels>(blogArticle);
 29             if (nextblog!=null)
 30             {
 31                 models.next = nextblog.btitle;
 32                 models.nextID = nextblog.bID;
 33             }
 34 
 35             if (prevblog != null)
 36             {
 37                 models.previous = prevblog.btitle;
 38                 models.previousID = prevblog.bID;
 39             }
 40             models.digest = Tools.ReplaceHtmlTag(blogArticle.bcontent).Length > 100 ? Tools.ReplaceHtmlTag(blogArticle.bcontent).Substring(0, 200) : Tools.ReplaceHtmlTag(blogArticle.bcontent);
 41             return models;
 42 
 43         }
 44 
 45 
 46     }
 47 }
View Code

2.3博客添加頁面實現功能

在區域admin的控制器下建立一個add方法用來展現頁面。

add方法

  1         public ActionResult Add()
  2         {
  3             return View();
  4         }
View Code

而後View添加視圖選擇使用佈局頁

image

佈局頁代碼

  1 
  2 @{
  3     ViewBag.Title = "添加博客";
  4 }
  5 
  6 <link href="~/Content/CSS/animate.css" rel="stylesheet" />
  7 <link href="~/Content/lib/wangEditor/dist/css/wangEditor.css" rel="stylesheet" />
  8 <link href="~/Content/CSS/blogArticleStyle.css" rel="stylesheet" />
  9 <script src="~/Content/lib/wangEditor/dist/js/wangEditor.js"></script>
 10 <script src="~/Scripts/jquery.unobtrusive-ajax.min.js"></script>
 11 <script type="text/javascript">
 12     $(function () {
 13         // 獲取元素
 14         var textarea = document.getElementById('bcontent');
 15         // 生成編輯器
 16         var editor = new wangEditor(textarea);
 17         // 自定義菜單
 18         editor.config.menus = [
 19         'source',
 20         '|',
 21         'bold',
 22         'underline',
 23         'italic',
 24         'eraser',
 25         'forecolor',
 26         'bgcolor',
 27         '|',
 28         'quote',
 29         'fontfamily',
 30         'fontsize',
 31         'head',
 32         'unorderlist',
 33         'orderlist',
 34         'alignleft',
 35         'aligncenter',
 36         'alignright',
 37         '|',
 38         'link',
 39         'unlink',
 40         'emotion',
 41         '|',
 42         'img',
 43         'insertcode',
 44         '|',
 45         'undo',
 46         'redo',
 47         'fullscreen'
 48         ];
 49         // 上傳圖片(舉例)
 50         editor.config.uploadImgUrl = '/admin/BlogArticle/upload';
 51         editor.config.uploadImgFileName = 'imgFile'
 52         editor.create();
 53     });
 54     //添加博文以後
 55     function afterAddBlog(data) {
 56         var serverData = data.split(':');
 57         if (serverData[0] == "ok")
 58         {
 59             alert(serverData[1]);
 60             window.location.reload();
 61         }
 62     };
 63 </script>
 64 <div class="blogcontent">
 65     <!-- head star -->
 66     <div class="tnav row border-bottom white-bg page-heading">
 67         <div class="col-sm-4">
 68             <h2 class="fl">博客後臺</h2>
 69             <ol class="breadcrumb fl">
 70                 <li><a href="/admin/Home">博客管理</a></li>
 71                 <li><strong>發佈博客</strong></li>
 72             </ol>
 73         </div>
 74     </div>
 75     <!-- head end -->
 76     <!-- form star -->
 77     <div class="">
 78         <div class="wrapper wrapper-content animated fadeInUp" style="height:600px;padding-bottom:30px;overflow:auto">
 79             @using (Ajax.BeginForm("Add", "BlogArticle", new { }, new AjaxOptions() { HttpMethod = "post", OnSuccess = "afterAddBlog" }, new { @class = "form-horizontal" }))
 80             {
 81                 <div class="form-group">
 82                     <label class="col-md-1 control-label">標題&nbsp;:</label>
 83                     <div class="col-md-11">
 84                         <input type='text' name='btitle' id='title' value='' class='form-control' placeholder='' />
 85                     </div>
 86                 </div>
 87                 <div class="form-group">
 88                     <label class="col-md-1 control-label">類別&nbsp;:</label>
 89                     <div class='col-md-2'>
 90                         <select name='bcategory' id='original' class='form-control'>
 91                             <option value='技術博文' selected='selected'>技術博文</option>
 92                             <option value='隨筆日誌'>隨筆日誌</option>
 93                         </select>
 94                     </div>
 95                 </div>
 96                 <div class="form-group">
 97                     <label class="col-md-1 control-label">內容&nbsp;:</label>
 98                     <div class='col-md-11'>
 99                         <textarea id="bcontent" rows="18" name="bcontent" class='form-control'>
100                             <p>請輸入內容...</p>
101                         </textarea>
102                     </div>
103                 </div>
104                 <div class="form-group">
105                     <div class="col-md-offset-1 col-md-10">
106                         <input type='submit' id='submit' class='btn btn-info' value='保存' data-loading='稍候...' />
107                     </div>
108                 </div>
109 
110             }
111         </div>
112     </div>
113     <!-- form end -->
114 </div>
115 
116 
117 
118 
View Code

效果圖

image

在控制器中添加一個上傳圖片的方法,用於富文本編輯器上傳圖片

upload方法

  1       //圖片上傳
  2         public ActionResult upload()
  3         {
  4             //文件保存目錄路徑
  5             String savePath = "/upload/";
  6 
  7             //定義容許上傳的文件擴展名
  8             Hashtable extTable = new Hashtable();
  9             extTable.Add("image", "gif,jpg,jpeg,png,bmp");
 10             extTable.Add("flash", "swf,flv");
 11             extTable.Add("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb");
 12             extTable.Add("file", "doc,docx,xls,xlsx,ppt,htm,html,txt,zip,rar,gz,bz2");
 13 
 14             //最大文件大小
 15             int maxSize = 1000000;
 16 
 17             HttpPostedFileBase imgFile = Request.Files["imgFile"];
 18             if (imgFile == null)
 19             {
 20                 return Content("error|請選擇文件。");
 21             }
 22 
 23             String dirPath = Server.MapPath(savePath);
 24             if (!Directory.Exists(dirPath))
 25             {
 26                 return Content("error|上傳目錄不存在。");
 27             }
 28 
 29             String dirName = Request.QueryString["dir"];
 30             if (String.IsNullOrEmpty(dirName))
 31             {
 32                 dirName = "image";
 33             }
 34             if (!extTable.ContainsKey(dirName))
 35             {
 36                 return Content("error|目錄名不正確。");
 37             }
 38 
 39             String fileName = imgFile.FileName;
 40             String fileExt = Path.GetExtension(fileName).ToLower();
 41 
 42             if (imgFile.InputStream == null || imgFile.InputStream.Length > maxSize)
 43             {
 44                 return Content("error|上傳文件大小超過限制。");
 45             }
 46 
 47             if (String.IsNullOrEmpty(fileExt) || Array.IndexOf(((String)extTable[dirName]).Split(','), fileExt.Substring(1).ToLower()) == -1)
 48             {
 49                 return Content("error|上傳文件擴展名是不容許的擴展名。\n只容許" + ((String)extTable[dirName]) + "格式。");
 50             }
 51 
 52             //建立文件夾
 53             dirPath += dirName + "/";
 54             if (!Directory.Exists(dirPath))
 55             {
 56                 Directory.CreateDirectory(dirPath);
 57             }
 58             String ymd = DateTime.Now.ToString("yyyyMMdd", DateTimeFormatInfo.InvariantInfo);
 59             dirPath += ymd + "/";
 60             if (!Directory.Exists(dirPath))
 61             {
 62                 Directory.CreateDirectory(dirPath);
 63             }
 64 
 65             String newFileName = DateTime.Now.ToString("yyyyMMddHHmmss_ffff", DateTimeFormatInfo.InvariantInfo) + fileExt;
 66             String filePath = dirPath + newFileName;
 67 
 68             imgFile.SaveAs(filePath);
 69 
 70             String fileUrl = savePath + "image/" + ymd + "/" + newFileName;
 71             return Content(fileUrl);
 72         }
View Code

調用的位置:

image

提交博客使用的是異步提交

image

在博客控制器添加一個add方法用來添加數據

add方法

  1         //新增博文
  2         [HttpPost]
  3         [ValidateInput(false)]
  4         public ActionResult Add(BlogArticle blogArticle)
  5         {
  6             blogArticle.bCreateTime = DateTime.Now;
  7             blogArticle.bsubmitter = "admin";
  8             blogArticle.bUpdateTime = DateTime.Now;
  9             blogArticle.bRemark = string.Empty;
 10             BlogArticleServive.Add(blogArticle);
 11             BlogArticleServive.SaverChanges();
 12             return Content("ok:添加成功!");
 13         }
View Code

記住在使用以前須要把接口和對應的方法實如今構造方法中調用

image

3、博客系統前臺佈局實現

3.1接下來就改前臺展現部分,一樣使用的是佈局頁

設計頁面以下:

image

前臺佈局頁_Layout.cshtml代碼:

  1 <!DOCTYPE html>
  2 <html>
  3 <head>
  4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  5     <meta charset="utf-8" />
  6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7     <link href="~/Content/CSS/zui.css" rel="stylesheet" />
  8     @*<link href="~/Content/CSS/zui-blog-theme.css" rel="stylesheet" />*@
  9     <link href="~/Content/CSS/zui-theme-blue.css" rel="stylesheet" />
 10     <link href="~/Content/CSS/HomeIndex.css" rel="stylesheet" />
 11     <link href="~/Content/CSS/pagerstyles.css" rel="stylesheet" />
 12     <title>@ViewBag.Title - WMBlog博客</title>
 13 
 14 
 15 </head>
 16 <body>
 17     <!--導航部分-->
 18     @Html.Partial("_NavbarPage")
 19     <!--主體內容-->
 20     <div class="main">
 21         <div class="row">
 22             <!--左邊主要內容-->
 23             @*<article style="margin-top: 10px;">
 24                     <div class="col-md-8" id="leftmain">
 25                         @RenderBody()
 26                     </div>
 27                 </article>*@
 28             <!--左邊主要內容-->
 29             <!--右邊欄-->
 30             <!--主題部分-->
 31             @{
 32                 if (ViewBag.controllername != "statistical")
 33                 {
 34                     <article style="margin-top: 10px;">
 35                         <div class="col-md-8" id="leftmain">
 36                             @RenderBody()
 37                         </div>
 38                     </article>
 39                     @Html.Partial("_RightPage")
 40                 }
 41                 else
 42                 {
 43                     @RenderBody()
 44                 }
 45 
 46             }
 47 
 48             <!--右邊欄-->
 49         </div>
 50     </div>
 51     <!--主題部分-->
 52     <!--底部版權部分-->
 53     @Html.Partial("_FooterPage")
 54 
 55     <script src="~/Content/JS/jquery-1.12.4.min.js"></script>
 56     <script src="~/Content/JS/zui.js"></script>
 57     <script src="~/Scripts/jquery.validate.js"></script>
 58     <script src="~/Scripts/jquery.validate.unobtrusive.js"></script>
 59     <script src="~/Scripts/jquery.unobtrusive-ajax.js"></script>
 60     <script type="text/javascript">
 61         $(function () {
 62             //用於控制導航樣式
 63             var name = '@ViewBag.controllername'
 64             $('#' + name).attr("class", "active")
 65         })
 66     </script>
 67     @RenderSection("scripts", false)
 68 </body>
 69 </html>
 70 
View Code

部分佈局頁導航部分_NavbarPage

  1   <!--導航-->
  2 <nav class="navbar navbar-default navbar-fixed-top">
  3     <div class="container">
  4         <!--小屏幕導航按鈕和logo-->
  5         <div class="navbar-header">
  6             <button class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
  7                 <span class="icon-bar"></span>
  8                 <span class="icon-bar"></span>
  9                 <span class="icon-bar"></span>
 10             </button>
 11             <a href="index.html" class="navbar-brand">WM Blog</a>
 12         </div>
 13         <!--小屏幕導航按鈕和logo-->
 14         <!--導航-->
 15         <div class="navbar-collapse collapse">
 16             <ul class="nav navbar-nav">
 17                 <li id="home"><a href="/home/index" id="index"><i class="icon icon-home"></i>&nbsp;首頁</a></li>
 18                 <li id="blog"><a href="/blog/index" id="content"><i class="icon icon-list-alt"></i>&nbsp;博文</a></li>
 19                 <li><a href="/movie/index"><i class="icon icon-film"></i>&nbsp;隨筆</a></li>
 20                 <li><a href="/statistical/index"><i class="icon icon-bar-chart"></i>&nbsp;訪問</a></li>
 21                 <li><a href="/about/index"><span class="icon icon-tags"></span>&nbsp;關於</a></li>
 22             </ul>
 23             <form class="navbar-form navbar-right" role="search">
 24                 <div class="form-group">
 25                     <input type="text" class="form-control" placeholder="搜索">
 26                 </div>
 27                 <button type="submit" class="btn btn-primary"><i class="icon icon-search"></i>&nbsp;搜索</button>
 28             </form>
 29         </div>
 30         <!--導航-->
 31 
 32     </div>
 33 </nav>
 34 <!--導航-->
 35 
 36 
View Code

部分佈局頁右側統計部分_RightPage

  1 <!--右邊欄部分-->
  2 <aside>
  3     <div class="col-md-4">
  4         <section class="youbianlan">
  5             <div class="panel-group">
  6                 <div class="panel">
  7                     <div class="panel-heading">
  8                         <div class="panel-title panel-info">
  9                             <h4>最新發布</h4>
 10                         </div>
 11                     </div>
 12                     <div class="panel-body">
 13                         <ul>
 14                             @{
 15                                 if (ViewBag.blogtimelist != null)
 16                                 {
 17                                     for (int i = 0; i < 10; i++)
 18                                     {
 19                                         <li><a href="/blog/Detail/@ViewBag.blogtimelist[i].bID">@ViewBag.blogtimelist[i].btitle</a></li>
 20                                     }
 21                                 }
 22 
 23                             }
 24                         </ul>
 25                     </div>
 26                 </div>
 27             </div>
 28         </section>
 29         <section class="youbianlan">
 30             <div class="panel-group">
 31                 <div class="panel">
 32                     <div class="panel-heading">
 33                         <div class="panel-title panel-info">
 34                             <h4>閱讀排行榜</h4>
 35                         </div>
 36                     </div>
 37                     <div class="panel-body">
 38                         <ul>
 39                             @{
 40                                 if (ViewBag.blogtrafficlist != null)
 41                                 {
 42                                     for (int i = 0; i < 10; i++)
 43                                     {
 44                                         <li><a href="/blog/Detail/@ViewBag.blogtrafficlist[i].bID">@ViewBag.blogtrafficlist[i].btitle</a></li>
 45                                     }
 46                                 }
 47 
 48                             }
 49                         </ul>
 50                     </div>
 51                 </div>
 52             </div>
 53         </section>
 54         <section class="youbianlan">
 55             <div class="panel-group">
 56                 <div class="panel">
 57                     <div class="panel-heading">
 58                         <div class="panel-title panel-info">
 59                             <h4>評論排行榜</h4>
 60                         </div>
 61                     </div>
 62                     <div class="panel-body">
 63                         <ul>
 64                             @{
 65                                 List<TopgbViewModels> list = ViewBag.blogguestbooklist as List<TopgbViewModels>;
 66                                 if (list != null && list.Any())
 67                                 {
 68                                     if (list.Count < 10)
 69                                     {
 70                                         for (int i = 0; i < list.Count; i++)
 71                                         {
 72                                             <li><a href="/blog/Detail/@list[i].blogId">@list[i].btitle</a></li>
 73                                         }
 74                                     }
 75                                     else
 76                                     {
 77                                         for (int i = 0; i < 10; i++)
 78                                         {
 79                                             <li><a href="/blog/Detail/@list[i].blogId">@list[i].btitle</a></li>
 80                                         }
 81                                     }
 82 
 83                                 }
 84 
 85                             }
 86                         </ul>
 87                     </div>
 88                 </div>
 89             </div>
 90         </section>
 91     </div>
 92 </aside>
 93 <!--右邊欄部分結束-->
 94 
 95 
View Code

部分佈局頁底部版權部分_FooterPage

  1     <!--頁腳部分-->
  2 <div id="footer_wrapper" class="col-md-12">
  3     <footer>
  4         <ul>
  5             <li><a href="content.html">版權信息</a></li>
  6             <li><a href="content.html">站點地圖</a></li>
  7             <li><a href="content.html">聯繫咱們</a></li>
  8         </ul>
  9         <p>Copyright ©2016 WMBlog</p>
 10     </footer>
 11 </div>
 12 <!--頁腳部分結束-->
 13 
View Code

3.2實現主頁面展現

在控制器下的文件夾中建立一個home控制器,而後建立一個index視圖頁面

index視圖頁代碼

  1 @model PagedList<Wchl.WMBlog.Model.Models.BlogArticle>
  2 @using Webdiyer.WebControls.Mvc
  3 @{
  4     ViewBag.Title = "首頁";
  5 }
  6 
  7 <section id="lunbotu">
  8     <div id="myNiceCarousel" class="carousel slide" data-ride="carousel">
  9         <!-- 圓點指示器 -->
 10         <ol class="carousel-indicators">
 11             <li data-target="#myNiceCarousel" data-slide-to="0" class="active"></li>
 12             <li data-target="#myNiceCarousel" data-slide-to="1"></li>
 13             <li data-target="#myNiceCarousel" data-slide-to="2"></li>
 14         </ol>
 15 
 16         <!-- 輪播項目 -->
 17         <div class="carousel-inner">
 18             @foreach (var item in ViewBag.adList)
 19             {
 20                 if (item == ViewBag.adList[0])
 21                 {
 22                     <div class="item active">
 23                         <a href="@item.Url" title="@item.Title" target="_blank">
 24                             <img alt="First slide" src="@item.ImgUrl">
 25                         </a>
 26                         <div class="carousel-caption">
 27                             <h3>@item.Title</h3>
 28                         </div>
 29                     </div>
 30                 }
 31                 else
 32                 {
 33                     <div class="item">
 34                         <a href="@item.Url" title="@item.Title" target="_blank">
 35                             <img alt="Second slide" src="@item.ImgUrl">
 36                         </a>
 37 
 38                         <div class="carousel-caption">
 39                             <h3>@item.Title</h3>
 40                         </div>
 41                     </div>
 42                 }
 43             }
 44             @*<div class="item active">
 45                     <a href="http://www.baidu.com" title="baidu" target="_blank">
 46                         <img alt="First slide" src="/upload/20161006/1.jpg">
 47                     </a>
 48                     <div class="carousel-caption">
 49                         <h3>我是第一張幻燈片</h3>
 50                     </div>
 51                 </div>
 52                 <div class="item">
 53                     <img alt="Second slide" src="/upload/20161006/2.jpg">
 54                     <div class="carousel-caption">
 55                         <h3>我是第二張幻燈片</h3>
 56                     </div>
 57                 </div>
 58                 <div class="item">
 59                     <img alt="Third slide" src="/upload/20161006/3.jpg">
 60                     <div class="carousel-caption">
 61                         <h3>我是第三張幻燈片</h3>
 62                     </div>
 63                 </div>*@
 64         </div>
 65 
 66         <!-- 項目切換按鈕 -->
 67         <a class="left carousel-control" href="#myNiceCarousel" data-slide="prev">
 68             <span class="icon icon-chevron-left"></span>
 69         </a>
 70         <a class="right carousel-control" href="#myNiceCarousel" data-slide="next">
 71             <span class="icon icon-chevron-right"></span>
 72         </a>
 73     </div>
 74 </section>
 75 <section id="boke">
 76     @foreach (var item in Model)
 77     {
 78         <div class="day">
 79             <div class="dayTitle">
 80                 <a class="btn btn-primary">@item.bCreateTime.ToString("yyyy年MM月dd日")</a>
 81             </div>
 82             <div class="postTitle">
 83                 <a id="1" class="postTitle2" href="/blog/Detail/@item.bID">@item.btitle</a>
 84             </div>
 85             <div class="postCon">
 86                 <div class="c_b_p_desc">
 87                     摘要:@item.bcontent......
 88                     <a href="/blog/Detail/@item.bID" class="btn btn-primary">閱讀全文</a>
 89                 </div>
 90             </div>
 91             <div class="postDesc">
 92                 <p>posted @@ @item.bCreateTime @item.bsubmitter 閱讀(@item.btraffic) 評論(@item.bcommentNum)  </p>
 93             </div>
 94         </div>
 95     }
 96 
 97     <footer class="pagination">
 98         @Ajax.Pager(Model, new PagerOptions { PageIndexParameterName = "pageindex", ContainerTagName = "ul", CssClass = "pager", CurrentPagerItemTemplate = "<li class=\"active\"><a href=\"#\">{0}</a></li>", DisabledPagerItemTemplate = "<li class=\"disabled\"><a>{0}</a></li>", PagerItemTemplate = "<li>{0}</li>" }, new MvcAjaxOptions { UpdateTargetId = "boke", OnBegin = "alert('onbegin事件引起')", OnSuccess = "handleSuccess", OnComplete = "function(xhr,status){alert('oncomplete事件引起,Http響應代碼:'+xhr.status+',響應內容:'+xhr.statusText+',狀態代碼:'+status)}", OnFailure = "handleFailure" })
 99         @*@Html.Pager(Model, new PagerOptions { PageIndexParameterName = "pageindex", ContainerTagName = "ul", CssClass = "pager", CurrentPagerItemTemplate = "<li class=\"active\"><a href=\"#\">{0}</a></li>", DisabledPagerItemTemplate = "<li class=\"disabled\"><a>{0}</a></li>", PagerItemTemplate = "<li>{0}</li>" })*@
100         @*@Html.Pager(Model, new PagerOptions { PageIndexParameterName = "pageindex", CurrentPagerItemTemplate = "<span class=\"current\">{0}</span>", DisabledPagerItemTemplate = "<span class=\"disabled\">{0}</span>", Id = "badoopager" })*@
101     </footer>
102 </section>
103 
104 
105 
106 
View Code

而後在控制器index下實現查詢博客信息代碼

  1  public ActionResult Index(int pageindex = 1)
  2         {
  3             //獲取控制器名稱
  4             ViewBag.controllername = RouteData.Values["controller"].ToString().ToLower();
  5 
  6             int pagesize = 6;
  7             //獲取發佈博文信息
  8             var blogArticleList = BlogArticleServive.QueryWhere(a => true).OrderByDescending(a => a.bCreateTime).ToPagedList(pageindex, pagesize);
  9             foreach (var item in blogArticleList)
 10             {
 11                 if (!string.IsNullOrEmpty(item.bcontent))
 12                 {
 13                     item.bcontent = Tools.ReplaceHtmlTag(item.bcontent);
 14                     if (item.bcontent.Length > 200)
 15                     {
 16                         item.bcontent = item.bcontent.Substring(0, 200);
 17                     }
 18                 }
 19 
 20             }
 21             //獲取輪播廣告新
 22             ViewBag.adList = AdvertisementServices.QueryOrderBy(a => true, a => a.Createdate, false).ToPagedList(1, 3);
 23             //發佈時間排序
 24             ViewBag.blogtimelist = BlogArticleServive.QueryOrderBy(c => true, c => c.bCreateTime, false);
 25             //評論排序
 26             ViewBag.blogtrafficlist = BlogArticleServive.QueryOrderBy(c => true, c => c.btraffic, false);
 27             //留言排序
 28             string sql = @"select a.*,b.btitle from (select blogId,count(1) as counts  from Guestbook group by blogId) as a
 29 inner join BlogArticle as b
 30 on
 31 b.bID=a.blogId order by counts desc";
 32 
 33             ViewBag.blogguestbooklist = GuestbookServices.RunProc<TopgbViewModels>(sql);
 34 
 35 
 36             return View(blogArticleList);
 37         }
View Code

效果展現:

image

image

image

4、博客系統發佈博客功能以及展現功能總結

    這裏使用到了的兩個插件一個是後臺的富文本編輯器;一個是mvc分頁插件,具體插件能夠去相應的官網查看詳細的使用方法,富文本編輯器官網:http://www.wangeditor.com/;mvc分頁插件官網:http://www.webdiyer.com/mvcpager/

     主要的分佈實現是使用到了mvc佈局頁來實現的,實現頁面功能的時候,通常都是先把靜態頁面作出來,而後在把前臺頁面移至到項目中,把須要展現數據的地方修改爲動態的就能夠了。

    這裏在說明一下個人文件夾設計我在Content文件夾下建立了CSS、fonts、images、JS、lib文件夾,把全部自定和用到的主要UI框架文件分類放在對應的文件夾中,lib文件夾主要放全部的第三方的插件文件,另外還添加了一個upload文件夾主要存放全部上傳的文件圖片的。

image

    以上博客中使用的文字信息來之IT之家網站,頁面佈局都是傳統的佈局方式,風格參考個人博客園的風格。

    下一篇博客會介紹系統中留言、輪播圖管理的實現,我會的也就這麼多了,但願你們多提提意見,有什麼不夠好的地方我會盡可能改正的,謝謝你們。

相關文章
相關標籤/搜索