ASP.NET MVC简单编程篇

ASP.NET MVC简单编程篇,第1张

ASP NET MVC概念

ASP NET MVC 是微软官方提供的MVC模式 说白了 ASP NET MVC知识开发ASP NET Web

应用程序的一个框架而已 而且其只是一个表示层框架 同时也是微软的第一个开源项目

使用ASP NET开发web应用程序方式

WebForm方式

Asp Net MVC 方式

注意 WebForm方式和Asp Net MVC方式是使用开发web应用程序的两种并行方式 mvc(以下简称mvc)的目的并不是取代WebForm 而是web开发的另外一种选择而已

MVC模式简介

MVC模式是一种表现模式 它将web应用程序分成三个主要组件 即 视图(View) 控制器(Controller)和模型(Model)

M Model主要是存储或者是处理数据的组件

Model其实是实现业务逻辑层对实体类相应数据库 *** 作 如CRUD(Create/Retrieve/Update/Delete) 它包括数据 验证规则 数据访问和业务逻辑等应用程序信息

V View是用户接口层组件 主要是将Model中的数据展示给用户

C Controller处理用户交互 从Model中获取数据并将数据传给指定的View

要点

M和V的实现代码分离 从而使同一个程序可以使用不同的表现形式 C存在的目的则是确保M和V的同步 一旦M改变 V应该同步更新

控制器隔离了业务逻辑和View耦合 使得业务逻辑和数据规则等很容易改变而不影响到前台页面

View和Controller都可以直接请求Model 但是Model不依赖View和Controller

Controller可以直接请求View来显示具体页面 View不依赖Controller

第一个Asp Net MVC程序

案例 下面我们通过向EFFirst数据库的Customer表中添加数据数据并且将所有用户信息展示到对应页面的方式 来书写第一个Asp Net MVC应用程序

Customer表结构

CustId(客户编号) 主键自动增长

CustName(客户姓名)

CustAddress(客户地址)

首先创建MVC 的项目

对解决方案点右键 新建项目 如下图

将项目名称命名为MyMVC 然后点击确定 如下图

选择否 点击确定

接下来对项目的目录结构进行剖析

App_Data在该文件夹下的文件是不同通过URL访问的 起到保护文件的作用

Content:项目用到的素材和样式等的文件夹 例如我们可以将Image文件夹和Css文件夹放到Content文件夹中

Controllers:控制器存储文件夹

Models 模型存放文件夹

Scripts js(javascript)文件存储文件夹

Views 视图存放文件夹

创建控制器UserInfoController

创建视图Register

Register页面对Controller发起请求 请求可以分两种 get和post 所以我们写了两个action 为了方便后续 *** 作 我们可以对action写一个重载 无参的Register()用来处理get请求 带参数的Register(FormCollection collection)用来处理post请求 如下图

然后对无参的Register点右键 选择添加视图菜单项

点击添加按钮 则在Views文件夹中会自动创建出一个名称为UserInfo(和action所在的控制器名称相同)的文件夹 并且在该文件夹下创建一个名称为Register的aspx文件 注意 这里的aspx文件没有后缀名为 cs的文件

在Register中书写代码如下所示

既然是注册页面 必须将用户输入的信息提交到服务器 此时我们可以使用form表单 为其action属性设置属性值为 /UserInfo/Register UserInfo代表的是UserInfoController Register代表UserInfoController下的action 也即是说我们将信息提交到了Register这个action

用户填写完信息后 流程跳转到了UserInfoController 此时我们可以在接收Post请求的action中书写如下代码

说明 return RedirectToAction( Index )作用是跳转到名称为Index的action继续执行

创建action Index和视图Index

用同样的方式对Index点右键 创建View Index

    <style type= text/css >             th td {                 text align: center             }         </style>         <h >微冷的雨 用户详细信息页面</h >         <h >由于顾客的数据肯定会出现多条 因此使用table显示</h >         <table width= % >             <thead>                 <tr>                     <td>编号</td>                     <td>用户姓名</td>                     <td>用户地址</td>                 </tr>             </thead>             <tbody>                <% foreach (var item in (IEnumerable<Customer>)ViewData[ Customer ])                   {%>                      <tr>                          <td><%:item CustId %></td>                          <td><%:item CustName %></td>                          <td><%:item CustAddress %></td>                      </tr>                   <%}                     %>             </tbody>         </table>    View Code    最终我们可以实现如下效果lishixinzhi/Article/program/net/201311/12164

因为本例涉及到数据库,所以在开始之前请先在数据库里新建一个名为“test”的数据库,里面新建一个表:“users”,表里有三个字段:

id(int,不可为null,设为标识符,自增),name(nvarcher(50)),age(nvarchar(50))

可以先在表里预设几条数据。

然后废话不多说,首先是 .aspx里的代码

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="test.aspx.cs" Inherits="test" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">

<head runat="server">

<meta http-equiv="Content-Type" content="text/htmlcharset=utf-8"/>

<title></title>

</head>

<body>

<form id="form1" runat="server">

<div>

<table runat="server" id="table1">

<tr>

<td>name:</td>

<td>

<asp:TextBox ID="tbName" runat="server"></asp:TextBox>

</td>

</tr>

<tr>

<td>age:</td>

<td>

<asp:TextBox ID="tbAge" runat="server"></asp:TextBox>

</td>

</tr>

<tr>

<td><asp:Button runat="server" ID="BtnAdd" text="add" OnClick="BtnAdd_Click"/></td>

<td><asp:Button runat="server" ID="BtnDel" text="del" OnClick="BtnDel_Click"/></td>

<td><asp:Button runat="server" ID="BtnUpdate" text="update" OnClick="BtnUpdate_Click"/></td>

<td><asp:Button runat="server" ID="BtnSelect" text="select" OnClick="BtnSelect_Click"/></td>

</tr>

</table>

</div>

</form>

</body>

</html>

这段代码中只有一个table,里面包含两个textbox用于显示name和age,还有四个按钮,分别用于增删改查,这6个控件都是asp标签,和正常的html标签类似,只不过多了一些ASP.NET封装的属性,方便与后台通信,后台可以通过其属性runat="server"知道控件运行于服务器,然后通过id即可访问到该控件,进而控制控件各种属性和显示。

下面是.aspx.cs的代码:

using System

using System.Collections.Generic

using System.Linq

using System.Web

using System.Web.UI

using System.Web.UI.WebControls

using System.Data.SqlClient

using System.Data.Sql

using System.Data

public partial class test : System.Web.UI.Page

{

//数据连接最基本需要的两个对象

private SqlConnection conn = null

private SqlCommand cmd=null

//private SqlDataAdapter adapter = null

//为了方便,设为全局对象的sql语句

private string sql = null

//公用 打开数据库的方法

public void openDatabase()

{

conn = new SqlConnection()

conn.ConnectionString = "Integrated Security=SSPIData Source=(local)initial catalog=testUser ID =你的用户名password=你的密码"

if (conn.State == ConnectionState.Closed)

{

conn.Open()

//Response.Write("<script>alert('Connected!')</script>")

}

}

//默认加载页面的方法 找到年龄最大的加载

//有些问题,年龄不能相同,加载中前台的textbox里只能显示一条记录,数据拿到之后有多条只显示一条

public void load()

{

openDatabase()

cmd = new SqlCommand("select * from users where age=(select max(age) from users)", conn)

SqlDataReader dr = cmd.ExecuteReader()

if (dr.Read())

{

tbName.Text = (String)dr[1].ToString().Trim()

tbAge.Text = (String)dr[2].ToString().Trim()

}

conn.Close()

}

//根据sql语句加载信息,重载两个textbox

public void load(String sql)

{

openDatabase()

cmd = new SqlCommand(sql, conn)

SqlDataReader dr = cmd.ExecuteReader()

while (dr.Read())

{

tbName.Text = (String)dr[1].ToString().Trim()

tbAge.Text = (String)dr[2].ToString().Trim()

}

conn.Close()

}

//封装的数据库语句执行的方法

public void execute(String sql)

{

openDatabase()

cmd = new SqlCommand(sql, conn)

cmd.ExecuteNonQuery()

conn.Close()

}

//页面加载时ASP.NET首先会调用这个方法

protected void Page_Load(object sender, EventArgs e)

{

if (!IsPostBack) { load()}//如果页面不是刷新,则执行,这个很重要

}

//四个按钮的方法,增删改查

protected void BtnAdd_Click(object sender, EventArgs e)

{

sql = "insert into users(name,age) values('"+ tbName.Text.ToString().Trim() +"','" + tbAge.Text.ToString().Trim() +"')"

execute(sql)

}

protected void BtnDel_Click(object sender, EventArgs e)

{

sql = "delete from users where name='" + tbName.Text.ToString().Trim() + "' and age='" + tbAge.Text.ToString().Trim()+"'"

execute(sql)

load()

}

protected void BtnUpdate_Click(object sender, EventArgs e)

{

sql = "update users set age='"+ tbAge.Text.ToString().Trim()+"' where name='" + tbName.Text.ToString().Trim() + "'"

execute(sql)

}

protected void BtnSelect_Click(object sender, EventArgs e)

{

sql = "select * from users where name='" + tbName.Text.ToString().Trim() + "'"

load(sql)

}

}

代码里没有任何异常处理的代码,没有验证,没有提示,只是很粗陋的东西,只为了让初学者明白连接数据库, *** 作数据的核心而已,所以在运行时如果出错不要慌张,很有可能你输入了我没有预料到的情况。

这时细读错误提示,通过理解代码,函数意图,然后找出我写的函数的错误,你会对代码有更好的理解,同时你也会思考如何避免用户误 *** 作的问题吧。

下面稍微解说下代码,主要是后台的代码。

连接数据库, *** 作数据库主要需要两个类,一个是SqlConnection,一个是SqlCommand

SqlConnection用于连接数据库,打开数据库,关闭数据库。

连接数据库需要特定格式,特定参数的字符串,如代码中写的,服务器地址,数据库名称,用户名密码,以及其他参数

SqlCommand用于 *** 作数据库,先创建基于一个特定SqlConnection对象的SqlCommand对象,通过ExecuteNonQuery方法执行给定的sql语句。

增删改都可以只是这样就 *** 作成功,但查询因为需要把数据读到一个地方,所以有一个新的对象出现了:SqlDataReader

通过SqlCommand对象的ExecuteReader方法得到一个SqlDataReader对象,SqlDataReader对象包含数据集,通过对SqlDataReader对象遍历即可取出查询的数据。

至此,增删改查都可以实现了。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9686885.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-30
下一篇2023-04-30

发表评论

登录后才能评论

评论列表(0条)

    保存