博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一步步打造漂亮的新闻列表(无刷新分页、内容预览)(2)
阅读量:6215 次
发布时间:2019-06-21

本文共 3057 字,大约阅读时间需要 10 分钟。

在中,我们进行了需求分析,如下:

1。动态的新闻列表(这个很简单)

2。可以分页读取新闻列表(这个也不难)

3。可以无刷新的分页读取新闻列表(这个稍微有点难度)

4。可以预览新闻的内容(这个也稍微有点难度)

5。界面友好(这个是必须的)

    按照软件工程的顺序,我们应按照这样的顺序开发软件:可行性分析===》需求分析===》概要设计===》详细设计===》编码===》测试

    由于我们仅仅是项目中的一个小部分,但也差不多按照以上的顺序进行开发,这是一个良好的习惯。我们将概要设计和详细设计放在一起。

    下面我们来设计数据库,由于采用的是Access数据库,而且字段也相对简单。就一张表tb_news,数据库名为news。

      名称                                 类型                长度

      news_id                               长整型                       4

      news_title                             文本                       255

      news_content                           内存                         -

      news_time                              日期/时间                     8

      news_readtimes                          长整型                       4

 

当然,你可以根据自己的需要增加字段或减少字段。其中news_content尽可能的长一些,符合新闻的长度。

数据库设计完毕后,我们可以开始编码了。首先建立asp.net项目(我比较偏向于web application,而不是website),将其命名为MyNewsList。如下图所示:

如果是用vs2010正式版,创建好后会发现会生成很多文件,它是vs2010自带的有些样式的页面(母版页),有点类似于asp.net mvc。这里我们不需要,将他们删除并且将一些文件夹重命名,将Account文件夹、About.aspx、Default.aspx、Global.asax和site.Mater删掉,并且将Scripts文件夹重命名为js文件夹;将Styles重命名为css文件夹,这样更符合我们的习惯,当然你也可以不改。并且将news数据库文件拷贝至App_Data文件夹。(如果你是vs2008或者其他版本,做类似的操作)最后的列表如下图:

 

ok,地基我们已经搭建好了,现在我们要筑房子了。建立NewsList.aspx页面,这就是我们的新闻列表页面。

在编辑NewsList.aspx之前,我们来先配置一下web.config文件,建立于数据库的连接。将<connectionStrings/>改为:

 
  1. <connectionStrings> 
  2. <add name="NewsConnection" connectionString="provider=Microsoft.Jet.OLEDB.4.0 ; Data Source=|DataDirectory|\news.mdb;"/> 
  3. </connectionStrings> 

我们注意到:Data Source=|DataDirectory|\news.mdb;中的DataDirectory,这就是为什么我们要将数据库文件拷贝到App_Data文件夹下,这样就很方便的调用数据库了,不必为路径的问题而烦恼了。

配好web.config文件后,我们开始设计前台。NewsList.aspx页面前台body的代码如下:

 
  1. <body> 
  2. <form id="form1" runat="server"> 
  3. <div> 
  4. <div id="tableData"> 
  5. <table cellpadding="5" cellspacing="1" width="90%" id="productTable" align="center"> 
  6. <tr> 
  7. <th style="width: 60%"> 
  8. <a style="cursor: pointer;">新闻的标题</a><span id="productid"></span> 
  9. </th> 
  10. <th style="width: 10%"> 
  11. <a style="cursor: pointer;">阅读次数</a><span id="UnitPrice"></span> 
  12. </th> 
  13. <th style="width: 30%"> 
  14. <a style="cursor: pointer;">发表</a><span id="Discontinued"></span> 
  15. </th> 
  16. </tr> 
  17. </table> 
  18. </div> 
  19. <div id="pagination" class="digg"> 
  20. </div> 
  21. </div> 
  22. </form> 
  23. </body> 
我们看到这是一个table,但里面并没有绑定或者写一些代码,这是为了以后使用ajax添加上去。同时我们注意到有这样的一些id
<span id="productid"></span>这是以后使用json绑定是需要的。
 
现在,我们来写一些后台代码,尝试着连接数据库。为了简单起见,我把连接数据库的代码写到NewsList.aspx的后台代码及NewsList.aspx.cs中,其实我们在实际的项目中,往往会把数据库操作的那块封装起了,只提供接口。
后台代码如下:
 
 
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Web;  
  5. using System.Web.UI;  
  6. using System.Web.UI.WebControls;  
  7. using System.Data.OleDb;  
  8. namespace MyNewsList  
  9. {  
  10. public partial class NewsList : System.Web.UI.Page  
  11. {  
  12. //数据库连接字符串  
  13. public static string connectionString = System.Web.Configuration.WebConfigurationManager.ConnectionStrings["NewsConnection"].ToString();  
  14. public static OleDbConnection conn;  
  15. protected void Page_Load(object sender, EventArgs e)  
  16. {  
  17. if (!Page.IsPostBack)  
  18. {  
  19. TestConnection();//测试连接数据库  
  20. }  
  21. }  
  22. protected void TestConnection()  
  23. {  
  24. conn = new OleDbConnection(connectionString);//创建新的连接  
  25. try  
  26. {  
  27. conn.Open();  
  28. if (conn.State == System.Data.ConnectionState.Open)  
  29. {  
  30. Response.Write("数据库连接成功");  
  31. }  
  32. else  
  33. {  
  34. Response.Write("连接状态是关闭的");  
  35. }  
  36. }  
  37. catch (Exception e)  
  38. {  
  39. Response.Write("连接失败,错误原因:"+e.Message);//如果连接失败将错误显示出来  
  40. }  
  41. finally  
  42. {  
  43. conn.Close();//一定要及时关掉conn  
  44. }  
  45. }  
  46. }  
当我们运行页面后发现“数据库连接成功”后,我们才开始下面的code编码。
    本文转自xshf12345 51CTO博客,原文链接:http://blog.51cto.com/alexis/573671,如需转载请自行联系原作者
    
你可能感兴趣的文章
Mac 应用程序开发的绝佳起点
查看>>
pyodps udf问题
查看>>
CocoaPods管理第三方
查看>>
EF,更好地管理
查看>>
倒计时特效的CountAnimationLabel
查看>>
iOS开发UI篇—使用picker View控件完成一个简单的选餐应用
查看>>
Code Jam练习
查看>>
tcmalloc浅析
查看>>
(一一三)第九章复习题
查看>>
拍立淘---试妆魔镜 OpenGL ES 2.0 框架及性能优化
查看>>
PostgreSQL HOT STANDBY using log shipping
查看>>
Autowired与Resource的区别
查看>>
send-mail: fatal: parameter inet_interfaces: no local interface found for ::1
查看>>
Shell基础之-cut命令
查看>>
node.js学习笔记(26) node-orm进阶一
查看>>
微信公众号网页开发——实用真机调试
查看>>
【译】函数组件和类组件有什么不同?
查看>>
Anka——渐进式小程序开发工具集
查看>>
《你不知道的Javascript--上卷 学习总结》(作用域)
查看>>
有赞996刷屏:男程序员们,别再低头写代码了
查看>>