来源:自学PHP网 时间:2015-04-14 14:51 作者: 阅读:次
[导读] 目前为止,您创建了电影网页,设置了它的样式,将它设计为受数据驱动,随后创建了一个窗体用于向数据库添加电影。下一步将是创建一个非常类似的窗体,用于编辑现有的电影列表...
目前为止,您创建了电影网页,设置了它的样式,将它设计为受数据驱动,随后创建了一个窗体用于向数据库添加电影。下一步将是创建一个非常类似的窗体,用于编辑现有的电影列表。 导读:Microsoft WebMatrix是一个免费的工具,可用于创建、自定义和在Internet上发布网站。 WebMatrix使您能够轻松创建网站。您可以从一个开源应用程序(比如WordPress、Joomla、 DotNetNuke或Orchard)开始,WebMatrix会为您处理下载、安装和配置这些应用程序的任务。或者您可以使用许多内置的模板自行编写代码,这些模板有助于您迅速上手。无论您做何选择,WebMatrix都提供了您的网站运行所需的一切内容,包括Web服务器、数据库和框架。通过在您的开发桌面使用与您将在Web主机上使用的相同堆栈,将网站上线的过程变得既轻松又顺利。 可以看到,它有一个电影列表,能够通过底部的链接添加影片。为了建立鼠标悬停效果,我们使用<a>标记将列表中每个电影条目设置为超链接。如果在希望编辑电影时只需使用此超链接,那将非常有用,那么我们看一下如何实现此功能。 创建编辑网页 首先,在WebMatrix中创建一个新CSHTML网页,将它命名为EditMovie.cshtml。此网页最终将包含一个窗体,其中填充了所选电影的详细信息,当您更改这些详细信息时,更改将提交回数据库。 将EditMovie.cshtml中的默认内容替换为这样一个窗体。该窗体非常类似于在上一部分中创建的窗体。 <h1>Edit a Movie</h1> 我们现在了解了编辑窗体的基本知识。但是如何使用您所选的特定电影的数据库内容来初始化该窗体?首先,我们看一下如何告诉此网页您希望编辑哪部电影,为此我们必须返回到dataMovies.cshtml网页。 您可能还记得,我们按照以下形式编写了一些列表项: <li><a href="#">@row.Name, @row.Genre, @row.ReleaseYear</a></li> <li><a href="EditMovie.cshtml ">@row.Name, @row.Genre, @row.ReleaseYear</a></li> EditMovie.cshtml?id=<something> <li><a href="@row.Name,@row.Genre,@row.ReleaseYearEditMovie.cshtml?id=@row.id">@row.Name,@row.Genre,@row.ReleaseYear</a></li> 它看起来没有任何区别,我们看一下此网页的HTML代码。这不是您在WebMatrix中看到的.cshtml网页,而是服务器(从cshtml中的指令)生成并发送给浏览器的HTML。 在Internet Explorer 9中,可以右键单击网页上的任何地方并选择“查看源代码”来查看此代码 1: <!DOCTYPE html> 完成编辑网页 我们返回到EditMovie.cshtml。 还记得之前我们看到,如果在网页顶部放置一个@{,并在其中写入代码,那么该代码就会在网页加载时执行。在这个位置放置代码来读取网页URL中包含的ID,然后使用该ID查找此电影的名称、类型和上映年份,这再好不过了。 当使用我们所使用的语法(即 PageName.cshtml?<Parameter>=<Value>)调用网页时,您可以使用Request对象找到参数的值。所以,如果EditMovie.cshtml?id=6,我们可以使用以下代码: var id=Request["id"]; 现在我们拥有了“id”,我们可以在SQL“SELECT”查询中使用它来查找该电影的记录。 1: var id=Request["id"]; 然后执行查询,将Name、Genre和ReleaseYear值加载到局部变量中。 这样做很好,但问题在于值位于变量中而不是窗体中,用户如何编辑它们呢?答案很简单,请记住此代码是在网页加载之前执行的,所以我们在写出HTML之前已拥有变量。而且正因为此,我们可以使用这些值初始化窗体。窗体使用<input>字段为我们提供文本框,这些字段支持“value”属性。我们现在可以直接在变量中使用此属性,以便初始化它们。 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com