设为首页 加入收藏
首 页 企业简介 项目案例 软件定制 行业软件 解决方案 下载中心 服务专区 客服中心
服务项目
案例展示 更多 >>
·维修管理系统 2012/5/14
·园区游客服务管理系统 2012/5/10
·党风廉政信息公开平台 2012/5/10
·餐饮无线点菜系统 2012/1/11
·职工提案系统软件 2012/1/11
·电信客户资源管理系统软… 2012/1/11
·移动停电通知系统 2012/1/11
·洗衣收银软件 2012/1/11
·触摸查询系统软件 2012/1/11
·西安来电弹屏软件 2011/8/31
联系人:李先生
电  话:029-87878512
手  机:13468700578
地  址:西安市太白北路1号
在线咨询:  762176615
Email:junsoft@126.com
 
当前的位置 >> 返回首页 >> 营销方案
软件开发过程中的技术点总结
发布者:西安软件公司   发布时间:2011/3/19   阅读:11次

1. ASP.NET AJAX 中,如何用 JavaScript 调用服务器端的方法?

这里不是指调用简单的 PageMethod,因为静态方法是不能操作当前页面的控件的,所以静态的 PageMethod 作用就跟普通的 WebService 一样,比较局限。
那么,调用一般的服务器端方法,其实就是发起一个异步回调。最简单的实现办法,是通过 UpdatePanel 来做。
首先定义一个隐藏的 LinkButton,在其处理事件中,去调用我们要执行的操作:

<asp:LinkButton ID="linkUpdatePosts" runat="server" style="display:'none';" OnClick
="linkUpdatePosts_Clicked"
 />

 

    // 刷新帖子列表(供客户端 js 调用)
    protected void linkUpdatePosts_Clicked(object sender, EventArgs e)
    {
        LoadPosts();
    }


然后 JavaScript 中就可以定义函数来触发这个 LinkButton 的回发:

    // 刷新帖子列表
    function refreshPosts() {
        __doPostBack(
'<%= linkUpdatePosts.UniqueID %>'''
);
    }

2. 如何获取 GridView 编辑状态下单元格里的值?

还在使用这样的代码吗?

var txtName = grid1.Rows[e.RowIndex].Cells[0].FindControl("txtName"as TextBox;
if (txtName != null
)
{
    
//
 读取值
    
//

}


其实这些工作(在单元格中查找控件,并尝试获取其中的值)已经被封装了。现在,只要调用 ExtractValuesFromCell 方法即可。
而该方法也被很多种列类型所支持:
DataControlField, BoundField, AutoGeneratedField, CheckBoxField, ImageField, TemplateField, DynamicField

你可以在 GridView 的 RowUpdating, RowDeleting 等事件中使用它。利用该方法,可以将值提取到所需的字典里去,然后再从字典中读取。这些字典包括:e.Keys, e.NewValues, e.OldValues 等。
一小段例子代码:

    // 更新
    protected void grid1_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        var row 
=
 grid1.Rows[e.RowIndex];
        
// 提取 Id 字段的值

        grid1.Columns[0].ExtractValuesFromCell(
            e.Keys,
            row.Cells[
0as
 DataControlFieldCell,
            DataControlRowState.Edit,
            
true /* include readonly */
);

        
// 提取 Name 字段的值

        grid1.Columns[1].ExtractValuesFromCell(
            e.NewValues,
            row.Cells[
1as
 DataControlFieldCell,
            DataControlRowState.Edit,
            
true /* include readonly */
);

        var id 
= int.Parse(e.Keys["id"
].ToString());
        var name 
= (string) e.NewValues["name"
];

        
//
 执行相关的数据库更新操作
        
//

    }


这样,在大多数场合我们可以尽可能多的使用 BoundField,并且也能正确读取到其编辑时的值,省下自定义 TemplateField 的一堆代码了。


网站首页 | 关于我们 | 售后服务 | 网站地图 | 查看留言 | 在线留言 | 客服中心
© 版权所有:西安润宇软件科技有限公司 
公司地址:西安市太白北路1号 联系电话:029-87878512 手机:13468700578 联系人:李先生
Copyright ® 2009-2017 Xbwbw.com Inc. All Rights Reserved 
技术支持:西安润宇软件科技有限公司  陕ICP备11000720号-1