[MVCSharp]开始使用MVC#
Getting started with MVC# framework
The source code of this example can be found under "Examples\Basics\" subfolder of the MVC# framework root folder. The framework itself can be downloaded from www.MVCSharp.org/download.aspx.
Introduction
The Model
Application logic
Main Task
Customers Controller
Orders Controller
Presentation
Customers view (Win)
Orders view (Win)
Customers view (Web)
Orders view (Web)
Customers view (Silverlight)
Orders view (Silverlight)
Starting the application
Summary
Introduction
Architectural
patterns such as Model-View-Controller are gaining more and more popularity
nowdays. The reason is simple: they improve applications' design and raise
their maintainability by splitting applications into three layers with distinct
responsibilities. However incorporating such patterns into an application
requires some effort - the fact that may discourage developers from using MVC
and similar approaches. Fortunately a number of frameworks exist, which
minimize the overhead of using architectural patterns such as MVC. One of such
frameworks is MVC#.
It assists developers in using the Model-View-Presenter pattern (an evolution
of MVC) by taking on itself all routine work, allowing to develop 3-tier MVP
applications with ease.
层MVP应用程序。
In
this article we will demonstrate how to build a Model-View-Presenter
application with the help of MVC# Framework. Our first example application will
be intended for managing customers and their orders. It will consist of two
views: first one displays customers and has a button to switch to the second
view. The second view lists orders for the selected customer and has buttons to
operate on the order selected: “Accept”, “Cancel” and “Ship”. We will implement
views for Windows, Web and Silverlight presentation platforms, revealing how
MVC# allows to target the same application to different presentation
mechanisms.
本文介绍如何使用MVC#框架构建一个MVP应用程序。我们的第一个示例程序打算管理客户和他们的订单。包括两个视图:一个是展示客户的,包含一个按钮来切换到第二个视图。第二个视图列出了所选择客户的订单列表,包括按钮来操作订单的选择:确定,取消,忽略。我们将实现Widows、Web和Silverlight的表现层。展示MVC# 如何支持不同的表现模式。
Before
reading the article be sure to get acquainted with the Model-View-Presenter
essentials. A gentle introduction to MVP and MVC can be found here.
Also note that the code listings throughout the article may omit minor details
for simplicity sake. For exact code see the example sources.
阅读本文之前请先熟悉MVP的必要知识。MVP和MVC的简单介绍请戳这里。还要说明的是文章中的代码可能会忽略一些细节,详细查看示例代码。
The Model 数据实体层
Firstly
we are going to create the model part of the MVP triad. It will consist of two
classes: Customer and Order. While the Customer class just holds a list of
orders and a static list of all customers, the Order is a little more
complicated having three operations.
namespace
MVCSharp.Examples.Basics.Model
{
publicclass Customer
{
publicstaticreadonly
List<Customer> AllCustomers = new
List<Customer>();
publicreadonly
List<Order> Orders = new
List<Order>();
privatestring name;
public Customer(string name)
{
this.name = name;
}
publicstring Name
{
get { return name; }
}
}
}
namespace
MVCSharp.Examples.Basics.Model
{
publicclass Order
{
private OrderState state = OrderState.Open;
public OrderState State
{
get { return state; }
}
publicvoid Accept()
{
if (State == OrderState.Open)
state = OrderState.Pending;
}
publicvoid Ship()
{
if (State == OrderState.Pending)
state = OrderState.Shipped;
}
publicvoid Cancel()
{
if (State != OrderState.Shipped)
state = OrderState.Cancelled;
}
}
}
Application Logic 应用逻辑层
Main Task 主任务
Every
MVC# application consists of one or more tasks. A task is an independent set of
actions which accomplish some job, typically representing a use case for the
system. Tasks may be "Book ticket", "Calculate taxes" and
others. In our example application there will be a single task for managing
customers and their orders. Each task consists of a number of views which a
user traverses to complete the task. Our example task will have two views:
"Customers" and "Orders".
所有的MVC#程序包含一个或者多个任务。一个任务是独立的一系列行为来实现一些工作,典型的代表系统中一个用例。任务可能是订票,计算税率或者其它的。在我们的程序中,只有一个任务来管理顾客和他们的订单。每个任务包括一系列的视图,用户完成任务。我们的示例中包含两个视图:顾客和订单。
In
order to describe a task we should declare its class. For each view a public
constant field, initialized with the view name, should be added to the task
class. According to the Model-View-Presenter pattern a view is never alone, it
always exists in pair with its controller (the view-controller pair is referred
to as interaction point), that is why for each view we also specify its
controller type with the [InteractionPoint] attribute.
为了描述一个任务,我们首先定义他的类。每个视图的静态字段,通过视图名称来初始化,应该被包含在任务类中。依照MVP模式,一个视图不是单独的,他总是和控制器成对存在(视图-控制器对代表交互点),那是为什么每个视图我们也在[InteractionPoint]属性中定义控制器类型的原因(Task类中的)。
publicclass MainTask
{
[InteractionPoint(typeof(CustomersController), Orders)]
publicconststring
Customers = "Customers";
[InteractionPoint(typeof(OrdersController), Customers)]
publicconststring
Orders = "Orders";
}
Besides
the controller type, [InteractionPoint] attribute specifies permitted
navigation targets. Thus above we have stated both Customers->Orders and
Orders->Customers transitions possible.
除了控制器类型,[InteractionPoint]属性定义了允许的导航目标,因而上面我们已经标记了Customers->Orders
和
Orders->Customers的转换。
In
MVC# all tasks should implement the ITask interface. Though this interface is
rather simple and can be implemented manually, the MVC# framework already comes
with a basic implementation TaskBase. We will use it as a base for our MainTask
class.
在MVC# 中,任务需要实现Itask接口。尽管这个接口是否简单,可以手动实现,MVC#框架已经实现了一个TaskBase基类。我们可以在我们的MainTask类中直接继承。
publicclass MainTask :
TaskBase
{
...
}
A part
of the ITask interface is the OnStart operation. It should be implemented to
define actions performed on task start. In our case we want the customers view
to be activated when the task starts:
ITask接口的一个方法是OnStart。需要被实现来定义一个任务开始时执行的操作。在我的示例中我们希望顾客视图被激活当任务开始的时候。
publicclass MainTask :
TaskBase
...
publicoverridevoid
OnStart(object param)
{
Navigator.NavigateDirectly(Customers);
}
NavigateDirectly
method activates a view regardless of the current view (which is null at the
beginning) and of possible navigation routes.
NavigateDirectly方法激活视图而不管当前视图和可能的导航路由。
A task
should be a container for global logic, used across the entire task and
consumed by more than one controller. In our example such global meaning will
have the currently selected customer. As we will see later it will be used by
both controllers. That is why we will include a CurrentCustomer property to the
MainTask. Moreover the setter for this property will generate a
CurrentCustomerChanged event:
一个任务应该是一个全局容器,在整个任务和消费的过程中被使用。在我们的示例中,这样的全局意味着当前选择的顾客。正如我们接下来将要看到,它将被控制器使用。这就解释了为什么我们的的MainTask包含CurrentCustomer属性。而且赋值给这一个属性将触发CurrentCustomerChanged事件。
publicclass MainTask :
TaskBase
...
private Customer currentCustomer;
publicevent EventHandler
CurrentCustomerChanged;
public Customer CurrentCustomer
{
get { return currentCustomer; }
set
{
currentCustomer = value;
if
(CurrentCustomerChanged != null)
CurrentCustomerChanged(this,
EventArgs.Empty);
}
}
Now we
are ready to deal with the rest of the application logic placed in the
controller classes. Let us start with the CustomersController class.
现在我们已经准备好可以处理控制器类中的应用程序逻辑了。我们从CustomersController开始。
Customers Controller
Generally
controllers in the Model-View-Presenter paradigm handle the application flow:
they process UI events using the Model tier classes when necessary, and decide
what to display in the UI. And so the CustomersController should do. First of
all it should configure the view with the customers list and the current
customer. This should be done during the initialization phase when the
controller is linked to its view:
一般的,MVP的控制器处理应用程序流程:必要时它们使用数据实体层的类来处理UI事件,并且决定在UI中显示。CustomersController正需要做这些事情。首先它需要配置视图的顾客列表和当前顾客,这应该在初始化过程中当控制器被连接到视图时完成。
namespace
MVCSharp.Examples.Basics.ApplicationLogic
{
publicclass
CustomersController : ControllerBase
{
publicoverride IView View
{
get { returnbase.View;
}
set
{
base.View = value;
(View as ICustomersView).SetCustomersList(Customer.AllCustomers);
(View as ICustomersView).CurrentCustomer =
(Task as MainTask).CurrentCustomer;
}
}
}
}
Note
that controllers in MVC# should conform to the IController interface. But as it
is with the ITask interface MVC# provides a common IController implementation
ControllerBase which we are using.
注意控制器在MVC#中需要继承Icontroller接口。但是正如Itask接口一样,MVC#提供了一个一般的ControllerBase类继承自Icontroller供我们使用。
Next,
CustomersController should process UI events. To be exact it should handle the
“Show Orders” command from the UI and process the change of the customer
currently selected in the customers form:
接下来,CustomersController需要处理UI事件。它应该处理顾客界面中的“显示订单”命令和当前用户改变的事件。
publicclass
CustomersController : ControllerBase
{
...
publicvoid ShowOrders()
{
Task.Navigator.Navigate(MainTask.Orders);
}
publicvoid
CurrentCustomerChanged()
{
(Task as MainTask).CurrentCustomer = (View as
ICustomersView)
.CurrentCustomer;
}
}
ICustomersView
is the interface that the customers view should implement:
IcustomersView接口是顾客视图应该实现的接口。
namespace
MVCSharp.Examples.Basics.ApplicationLogic
{
publicinterface ICustomersView
{
void SetCustomersList(List<Customer> customers);
Customer CurrentCustomer
{
get;
set;
}
}
}
Orders Controller
The
logic of displaying orders is quite simple: we should track the change of
current customer and display its orders:
显示订单的逻辑非常简单:我们需要跟踪当前用户的改变,并展示它的订单。
publicclass OrdersController
: ControllerBase
{
publicoverride ITask Task
{
get { returnbase.Task;
}
set
{
base.Task = value;
(Task as MainTask).CurrentCustomerChanged += CurrentCustomerChanged;
}
}
privatevoid
CurrentCustomerChanged(object sender,
EventArgs e)
{
(View as IOrdersView).SetOrdersList((Task as
MainTask).CurrentCustomer.Orders);
}
}
In the
above code we first subscribe to the MainTask.CurrentCustomerChanged event as
soon as the controller is linked to the task object. Then we just handle the
customer change event by passing the corresponding orders to the view.
上面的代码首先订阅了MainTask. CurrentCustomerChanged事件,当OrdersController控制器被连接到task对象时。接着我们传递相应的订单给视图来处理顾客改变事件。
The
next three methods represent the "Accept", "Ship", and
"Cancel" operations on the currently selected order:
下面的三个方法代表:在当前选择的订单上的“确定”,“忽略”和“取消”操作。
publicclass OrdersController
: ControllerBase
{
…
publicvoid AcceptOrder()
{
(View as IOrdersView).CurrentOrder.Accept();
UpdateView();
}
publicvoid ShipOrder()
{
(View as IOrdersView).CurrentOrder.Ship();
UpdateView();
}
publicvoid CancelOrder()
{
(View as IOrdersView).CurrentOrder.Cancel();
UpdateView();
}
}
We
might demand the view to disable certain operations depending on the current
order state. For example one cannot ship an order before it is accepted.
UpdateView is the method that analyzes the current order state and tells the
view to enable/disable certain operations:
我们可能要求视图取消特定的操作根据当前订单状态。例如不能在接受某个订单前选择忽略。UpdateView方法分析当前订单状态,并告知视图特定的操作可用或不可用。
publicclass OrdersController
: ControllerBase
…
privatevoid UpdateView()
{
if ((View as IOrdersView).CurrentOrder == null) return;
OrderState os = (View as
IOrdersView).CurrentOrder.State;
(View as IOrdersView).SetOperationsEnabling(
os == OrderState.Open, os == OrderState.Pending,
(os == OrderState.Open) || (os == OrderState.Pending));
}
The
OrdersController class should also have a CurrentOrderChanged operation for the
view to notify the controller when a user clicks on another order:
OrdersController订单控制器类也需要有CurrentOrderChanged操作,让视图在用户单击其他订单时通知控制器。
publicclass OrdersController
: ControllerBase
…
publicvoid
CurrentOrderChanged()
{
UpdateView();
}
Presentation
The
presentation layer consists of view classes. All views in MVC# should implement
the IView interface. In addition view classes should conform to particular interfaces
dictated by the application logic layer. In our example such interfaces are
ICustomersView and IOrdersView. Depending on the presentation platform chosen,
view classes should inherit an appropriate base view class (either Windows
form, or Web form, or Silverlight user control). We will design views for all
three platforms supported at the moment (Windows, Web and Silverlight) and will
start with Windows form views.
表现层包括视图类。所有的视图在MVC#中需要实现Iview接口。此外视图类需要针对应用程序逻辑层实现特定的接口。在我们的示例中,这些接口是ICustomersView
和IordersView接口。根据不同的表现平台,视图类需要继承合适的视图基类。或者是Windows
Form或者是WebForm或者是Silverlight用户控件。我们将为这三种平台提供视图。以Windows
Form开始介绍。
Customers view (Win)
First
let us create the customers view for the Windows Forms presentation mechanism.
As mentioned above it should be a subclass of the Windows Form class and should
implement the IView interface. To reduce the amount of manual work we will make
it inherit from the WinFormView class - a simple Form subclass implementing the
IView interface.
首先我们创建顾客视图的WindowsForm表现样式。像上面提到的,应该是Winform的子类并且实现Iview接口。为了减少人工的工作量我们通过继承WinFormView类。一个简单的实现了Iview的窗体类。
namespace
MVCSharp.Examples.Basics.Presentation
{
publicpartialclass
CustomersForm : WinFormView
{
public CustomersForm()
{
InitializeComponent();
}
}
}
Let us
place a GridView component and a button on the form:放置一个GirdView控件和一个按钮。
In
order for the customers controller to talk to its view the latter should
implement the ICustomersView interface:
为了让顾客控制器能够和它的视图会话,后者应该实现IcustomersVIew接口。
publicpartialclass
CustomersForm : WinFormView, ICustomersView
...
publicvoid SetCustomersList(List<Customer>
customers)
{
customersGridView.DataSource = customers;
}
public Customer CurrentCustomer
{
get { return customersGridView.CurrentRow == null ? null :
customersGridView.CurrentRow.DataBoundItem as
Customer;}
set { customersGridView.CurrentCell = customersGridView.Rows[
(customersGridView.DataSource as
IList).IndexOf(value)].Cells[0];}
}
According
to the MVP pattern views receive the user actions and then pass control to the
controller. In our case the customers view should handle the change of current
customer in the grid and the “Show Orders” button click:
依据MVP模式,视图接受用户的动作接着传递给控制器控制。在我们的示例中顾客视图应该处理当前用户改变的Gird事件和显示订单按钮的单击事件。
publicpartialclass
CustomersForm : WinFormView, ICustomersView
...
privatevoid
customersGridView_CurrentCellChanged(object sender, EventArgs e)
{
(Controller as CustomersController).CurrentCustomerChanged();
}
privatevoid
showOrdersButton_Click(object sender,
EventArgs e)
{
(Controller as CustomersController).ShowOrders();
}
The
last thing here is to point the MVC# framework that the above view class
describes the “Customers” view in the MainTask task. This is done with the View
attribute:
最后的事情是告诉MVC#框架,上面的视图类描述的是在MainTask任务中的顾客视图。这在视图属性中实现。
[View(typeof(MainTask), MainTask.Customers)]
publicpartialclass
CustomersForm : WinFormView, ICustomersView
…
Orders view (Win)
Similarly
let us design the OrdersView form. It will contain a grid and three buttons:
类似的我们设计OrdersView订单窗体。他包括一个grid控件和三个按钮。
In the
same manner as it was with the CustomersView, the OrdersView class should
inherit from the WinFormView class and implement the IOrdersView interface for
the framework and the controller to interact with it. It should also have a
[View] attribute to indicate its belonging to the main task as the
"Orders" view.
和顾客视图类似,订单视图应该集成自WinFormView,应该实现IordersView接口,这样控制器才能与之交互。他还应该包含[View]属性来标识它是属于主任务的Orders视图。
[View(typeof(MainTask), MainTask.Orders)]
publicpartialclass
OrdersForm : WinFormView, IOrdersView
{
...
publicvoid SetOrdersList(List<Order>
orders)
{
ordersGridView.DataSource = orders;
}
public Order CurrentOrder
{
get { return ordersGridView.CurrentRow.DataBoundItem
as Order; }
}
publicvoid SetOperationsEnabling(bool
acceptIsEnabled,
bool shipIsEnabled, bool
cancelIsEnabled)
{
acceptOrderBtn.Enabled = acceptIsEnabled;
shipOrderBtn.Enabled = shipIsEnabled;
cancelOrderBtn.Enabled = cancelIsEnabled;
}
The
following code shows how the OrdersForm handles user actions and delegates
processing to the controller:
下面的订单窗体出来用户动作,将处理交由控制器执行。
publicpartialclass
OrdersForm : Form, IView, IOrdersView
{
...
privatevoid
ordersGridView_CurrentCellChanged(object sender, EventArgs e)
{
(Controller as OrdersController).CurrentOrderChanged();
}
privatevoid
acceptOrderBtn_Click(object sender, EventArgs e)
{
(Controller as OrdersController).AcceptOrder();
}
privatevoid
shipOrderBtn_Click(object sender, EventArgs e)
{
(Controller as OrdersController).ShipOrder();
}
privatevoid cancelOrderBtn_Click(object
sender, EventArgs e)
{
(Controller as OrdersController).CancelOrder();
}
Customers view (Web)
In Web
environment the views design will be very similar to that in Windows. Views
will inherit from the WebFormView class and will contain a grid and buttons on
their surface:
ICustomersView
implementation will be identical to that in Windows environment:
publicpartialclass
_Default : WebFormView, ICustomersView
{
publicvoid
SetCustomersList(List<Customer> customers)
{
CustomersGridView.DataSource = customers;
}
public Customer CurrentCustomer
{
get { return (CustomersGridView.DataSource as
List<Customer>)
[CustomersGridView.SelectedIndex]; }
set { CustomersGridView.SelectedIndex =
(CustomersGridView.DataSource as
IList).IndexOf(value); }
}
}
Button
click and grid row selection event handler will look the same way too:
publicpartialclass
_Default : WebFormView, ICustomersView
...
protectedvoid
ShowOrdersButton_Click(object sender,
EventArgs e)
{
(Controller as CustomersController).ShowOrders();
}
protectedvoid
CustomersGridView_SelectedIndexChanged(object
sender, EventArgs
e)
{
(Controller as CustomersController).CurrentCustomerChanged();
}
Orders view (Web)
Here
we do not list code for the orders Web form class as it is very similar to its
Windows analogue above. If desired, a reader may look into the full sources of
the example. Here is how the orders Web view looks in the designer surface:
To
associate the designed Web forms with the "Customers" and
"Orders" views of the main task we use a slightly different technique
(instead of [View] attributes): we add [WebformsView] attributes to a
placeholder class inside the Global.asax file:
<!------------------------
Global.asax file -------------------->
<script
runat="server">
[WebformsView(typeof(MainTask), MainTask.Customers, "Default.aspx")]
[WebformsView(typeof(MainTask), MainTask.Orders, "Orders.aspx")]
class ViewDescriptions { }
</script>
Customers view (Silverlight)
Views
under Silverlight platform should inherit the UserControlView class.
Thus, firstly we should create a new user control with the following XAML
markup:
<mvc:UserControlView
xmlns:my=
"clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data"
x:Class="MVCSharp.Examples.Basics.Presentation.Silverlight.CustomersPage"
xmlns="http://schemas.microsoft.com/client/2007"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mvc="clr-namespace:MVCSharp.Silverlight;assembly=MVCSharpSL">
<Grid>
</Grid>
</mvc:UserControlView>
Next,
we are adding the customers data grid and the "Show Orders" button:
<mvc:UserControlView
... >
<Grid Background="White" Margin="5"
HorizontalAlignment="Left">
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
</Grid.RowDefinitions>
<my:DataGrid x:Name="CustomersGrid"
MaxWidth="400" MinHeight="100"
Grid.Row="0" SelectionMode="Single"
SelectionChanged="CustomersGrid_CurrentCellChanged"/>
<Button Width="75" Height="25"
HorizontalAlignment="Right" Grid.Row="1"
Content="Show Orders" Margin="3" Click="Button_Click"/>
</Grid>
Finally,
we should add the event handlers to the code-behind CustomersPage.xaml.cs file,
and make the view class implement the ICustomersView interface.
The corresponding code looks almost identical to that for Winforms and Web
platforms:
[View(typeof(MainTask), MainTask.Customers)]
publicpartialclass
CustomersPage : UserControlView, ICustomersView
...
publicvoid
SetCustomersList(List<Customer> customers)
{
CustomersGrid.ItemsSource = customers;
}
public Customer CurrentCustomer
{
get { return
CustomersGrid.SelectedItem as Customer; }
set { CustomersGrid.SelectedItem = value; }
}
privatevoid
CustomersGrid_CurrentCellChanged(object sender,
EventArgs e)
{
(Controller as CustomersController).CurrentCustomerChanged();
}
privatevoid Button_Click(object
sender, RoutedEventArgs e)
{
(Controller as CustomersController).ShowOrders();
}
Note
that for binding the view class to the task we are using the [View] attribute,
like we did for the Windows Forms platform.
Orders view (Silverlight)
And
again, we omit the description of the steps here, as everything is similar to
what we have done already. If necessary, see the example sources.
Starting the application
Every
MVC# application requires some configuration steps. All configuration data is
encapsulated in MVCConfiguration class instances. However instead of manually
setting up MVCConfiguration objects it is possible to obtain preconfigured
instances by the view managers' GetDefaultConfig() static method. After the
configuration is done it is time to start the task by passing its type to the
TasksManager.StartTask(...) method.
The
code to configure and to start the main task looks similar in Windows and Web
environments, the major difference is where to place that code. In Windows
application we put it in the Main method which is an entry point of a program:
staticclass Program
{
[STAThread]
staticvoid Main()
{
TasksManager tasksManager
= new TasksManager(WinformsViewsManager.GetDefaultConfig());
tasksManager.StartTask(typeof(MainTask));
Application.Run(Application.OpenForms[0]);
}
}
In Web
applications we place the main task start code in the session start handler in
Global.asax file:
<!----------------------
Global.asax file -------------------->
<script
runat="server">
...
void Session_Start(object
sender, EventArgs e)
{
TasksManager tm = new TasksManager(WebformsViewsManager.GetDefaultConfig());
tm.StartTask(typeof(MainTask));
}
As for
Silverlight platform, we use the Startup event handler of the global
application class to start the main task:
publicpartialclass App :
Application
...
privatevoid
Application_Startup(object sender, StartupEventArgs e)
{
TasksManager tasksManager = new TasksManager(SilverlightViewsManager.GetDefaultConfig());
tasksManager.StartTask(typeof(MainTask));
}
Summary
This
example gives the general look on how to construct layered applications with
MVC# framework. It demonstrates the common idea of the Model-View-Presenter
approch - that is breaking an application into three layers: one for business
objects (model), another for application logic (controllers), and the last for
presentation (views). And it shows how MVC# simplifies implementing the MVP
approach in your applications.
The
source code of this example can be found under "Examples\Basics\"
subfolder of the MVC# framework root folder. The framework itself can be
downloaded from www.MVCSharp.org/download.aspx.
[MVCSharp]开始使用MVC#的更多相关文章
- [MVCSharp]MVC# Overview概述
MVC# Overview概述 Abstract: This article gives an overview of MVC# - a Model-View-Presenter framework ...
- Asp.Net Mvc 使用WebUploader 多图片上传
来博客园有一个月了,哈哈.在这里学到了很多东西.今天也来试着分享一下学到的东西.希望能和大家做朋友共同进步. 最近由于项目需要上传多张图片,对于我这只菜鸟来说,以前上传图片都是直接拖得控件啊,而且还是 ...
- .Net Core MVC 网站开发(Ninesky) 2.4、添加栏目与异步方法
在2.3中完成依赖注入后,这次主要实现栏目的添加功能.按照前面思路栏目有三种类型,常规栏目即可以添加子栏目也可以选择是否添加内容,内容又可以分文章或其他类型,所以还要添加一个模块功能.这次主要实现栏目 ...
- ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第二章:利用模型类创建视图、控制器和数据库
在这一章中,我们将直接进入项目,并且为产品和分类添加一些基本的模型类.我们将在Entity Framework的代码优先模式下,利用这些模型类创建一个数据库.我们还将学习如何在代码中创建数据库上下文类 ...
- ASP.NET Core MVC/WebAPi 模型绑定探索
前言 相信一直关注我的园友都知道,我写的博文都没有特别枯燥理论性的东西,主要是当每开启一门新的技术之旅时,刚开始就直接去看底层实现原理,第一会感觉索然无味,第二也不明白到底为何要这样做,所以只有当你用 ...
- ASP.NET Core 中文文档 第四章 MVC(3.8)视图中的依赖注入
原文:Dependency injection into views 作者:Steve Smith 翻译:姚阿勇(Dr.Yao) 校对:孟帅洋(书缘) ASP.NET Core 支持在视图中使用 依赖 ...
- 开源:Taurus.MVC 框架
为什么要创造Taurus.MVC: 记得被上一家公司忽悠去负责公司电商平台的时候,情况是这样的: 项目原版是外包给第三方的,使用:WebForm+NHibernate,代码不堪入目,Bug无限,经常点 ...
- Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)
背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...
- Taurus.MVC 2.0 开源发布:WebAPI开发教程
背景: 有用户反映,Tausus.MVC 能写WebAPI么? 能! 教程呢? 嗯,木有! 好吧,刚好2.0出来,就带上WEBAPI教程了! 开源地址: https://github.com/cyq1 ...
随机推荐
- Yii2 Format 如何使用
$formatter = \Yii::$app->formatter; // output: January 1, 2014 echo $formatter->asDate('2014-0 ...
- 清橙 A1206 小Z的袜子(莫队算法)
A1206. 小Z的袜子 时间限制:1.0s 内存限制:512.0MB 总提交次数:1357 AC次数:406 平均分:46.75 将本题分享到: 查看未格式化的试题 ...
- linux消息队列的使用及内核实现原理
mq_receive NAME mq_open - open a message queue SYNOPSIS #include <fcntl.h> /* For O_* constant ...
- 《Java核心技术卷二》笔记(一)流与文件
一.流的概念 在Java中,可以提供字节序列的对象,或者可以接收字节序列的对象,都可以抽象成流.系统中的文件,网络,内存这些设备都可以读入或者写入字节,自然也可以用流的方式来操作.能向程序中提供字节序 ...
- web接入层 传入参数的格式化及web返回值传出数据的参数格式化,都要统一
1.web接入层 传入参数的格式化及web返回值传出数据的参数格式化,都要统一. 比如acSpace中, 传入层参数@RequestBody javaBean对象.统一转换为javabean传入参数. ...
- ecshop缓存清理-限制或禁用ECShop缓存
ecshop缓存清理-限制或禁用ECShop缓存 ECSHOP的缓存存放在templates/caches/文章夹下,时间长了这个文件夹就会非常庞大,拖慢网站速度.还有很多情况我们不需要他的缓存. ...
- MYSQL导入导出.sql文件
MYSQL导入导出.sql文件 一.MYSQL的命令行模式的设置:桌面->我的电脑->属性->环境变量->新建->PATH=“:path\mysql\bin;”其中p ...
- 完美解决VS2003.Net fatal error LNK1201: 写入程序数据库“.pdb”时出错
我的开发环境是Win7旗舰64位+VS2003.Net,经常卡pdb错误,文末给出一个完美的解决方案和一个懒人补丁包.问题描述如下:在重新编译的时候,经常报错: fatal error LNK1201 ...
- /etc/hosts.conf
一 作用 指定如何解析主机域名.可设置网络安全. 二 参数说明 默认情况,/etc/hosts.conf 文件有如下内容—— order hosts,bind ...
- P1149 火柴棒等式
#include <bits/stdc++.h> using namespace std; const int num[] = {6, 2, 5, 5, 4, 5, 6, 3, 7, 6} ...