asp.net前端优化

 本文介绍一些aps.net下前端页面应该注意的地方。以下仅是一部分简单的介绍,以后有时间会陆续更新并且提供代码(本人刚开始写博客,欢迎各位博友批评指正,同时希望有机会能和大家一起交流学习,220897863程序员之家群欢迎大家加入)

      1. 数据绑定控件的选择,在我们进行数据绑定时尽量使用Repeater控件,避免使用复杂控件尤其是gridview,Repeater控件简单的通过循环遍历生成数据,效率相比gridview要高。其次如果我们使用gridview,应该尽量避免使用gridview的自带分页,gridview自带分页需要读取全部数据,给数据里带来很大压力,采用存储过程分页返回记录总数和当前页的数据,在我现在的项目中通过 ajax请求,将记录总数和当前页数据采用json的格式返回到客户端,由客户端根据记录总数生成分页导航并且展示当前页数据。

       2. 作为aps.net的开发人员,很多程序员已经习惯了拖控件的方式,服务器控件的方便易用,确实提高了开发效率,但是随之带来的就是性能问题。一大堆的viewstate视图状态,一是影响带宽,传输速度。二是页面每次加载时都要进行初始化,结束时都要进行保存。我们知道服务器控件最终还是要转化为html控件并且用户每操作一次服务器端控件,就产生一次与服务器端的往返过程。因此非必要,应当少使用Server Control。我们可以通过html控件ajax技术来实现异步请求(jquery,httphandler来处理)  

       3. 对于不需要使用session的页面我们应该禁用session,因为Session实现了Reader/Writer的锁机制:当页面对Session具有可写功能(即页面有标记),此时直到请求完成该页面的Session持有一个写锁定。页面对Session具有只读功能(即页面有标记),此时知道请求完成该页面的Session持有一个读锁定。读锁定将阻塞一个写锁定;读锁定不会阻塞读锁定;写锁定将阻塞所有的读写锁定。这个和sql server中的共享锁,排它锁的机制是一样。我们可以通过页面上的EnableSessionState设置来指定是否使用session。

       4.  页面输出缓存作为最简单的缓存形式,输出缓存只是在内存中保留为响应请求而发送的 HTML 的副本。其后再有请求将提供缓存的输出,直到缓存到期,这样,性能有可能得到很大的提高取决于需要多少开销来创建原始页面输出 - 发送缓存的输出总是很快,并且比较稳定)

       5. 动态页面静态化,将动态的页面转化成静态的html页面,比如新闻系统,我们可以定义一个新闻模板,将发布的内容替代模板中的占位符。页面输出缓存也可以理解为是一种动态页面静态化的方式,将内容静态化到内存中。

 

转载于:https://www.cnblogs.com/suchen1314/archive/2012/03/15/2398539.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将 ASP.NET 前端输入的数据保存到数据库中,你需要完成以下步骤: 1. 创建数据库表格:在数据库中创建一个表格,用于存放你要保存的数据。表格应该包含与你要保存的数据相关的列。 2. 创建数据库连接:在你的 ASP.NET 代码中创建一个数据库连接,以便你能够将数据保存到数据库中。 3. 获取前端输入数据:使用 ASP.NET 的控件(例如 TextBox 或 DropDownList)来获取用户在前端输入的数据。 4. 处理用户输入数据:在你的 ASP.NET 代码中,验证和处理用户输入数据来确保它们符合你的要求。 5. 将数据保存到数据库:使用 SQL 语句将经过处理的数据保存到数据库中。 下面是一个简单的示例代码,用于将用户输入的数据保存到数据库中: ```csharp // 创建数据库连接 SqlConnection conn = new SqlConnection("Data Source=YourServerName;Initial Catalog=YourDatabaseName;Integrated Security=True"); // 打开数据库连接 conn.Open(); // 获取前端输入数据 string username = txtUsername.Text; string password = txtPassword.Text; // 处理用户输入数据 // ... // 将数据保存到数据库 SqlCommand cmd = new SqlCommand("INSERT INTO Users (Username, Password) VALUES (@Username, @Password)", conn); cmd.Parameters.AddWithValue("@Username", username); cmd.Parameters.AddWithValue("@Password", password); cmd.ExecuteNonQuery(); // 关闭数据库连接 conn.Close(); ``` 请注意,这只是一个简单的示例,你需要根据你的具体需求进行修改和优化

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值