栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

ExtJs学习笔记_Basic GridPanel

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

ExtJs学习笔记_Basic GridPanel

1.静态示例:

静态示例其实官方下载包里,就有sample,这里只贴出代码,后面的如何跟WCF结合,做出动态版的Grid才是本文重点




    
    
     
     
    ExtJs Study

Hello World



 

2.动态示例

先贴出运行效果图

 

 

a.先写wcf服务端
(1)新建一个"启用了Ajax的WCF服务",命名为MyService.svc

(2)写一个方法用于取得网格所需的数据

[ServiceContract(Namespace = "")]
    [AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
    public class MyService
    {

        [OperationContract]
        [WebInvoke(ResponseFormat = WebMessageFormat.Json, Method = "GET", UriTemplate = "GetClsData")]
        public T_Class[] GetClsData()
        {
            List _Result = new List();
            using (DBDataContext db = new DBDataContext())
            {
                var query = db.T_Classes.Where(c => c.F_Type.ToLower() == "shop").OrderBy(c => c.F_RootID).ThenBy(c => c.F_Orders).Select(c => new { F_ID = c.F_ID, 

F_ClassName = c.F_ClassName, F_ParentID = c.F_ParentID,F_Orders = c.F_Orders,F_ReadMe = c.F_ReadMe });
                _Result = db.ExecuteQuery(query, true).ToList();
                db.Connection.Close();
            }
            return _Result.ToArray();
        }
}


 

注意:这里是用linq to sql的方法写的,默认情况下linq to sql设计器生成的T_Class类里,是不支持序列化的,ExtJs调用时无法正确序列成JSON字符串,需要手动在类前加上数据契约

[DataContract],在属性前加上[DataMember]
如下:
[Table(Name="dbo.T_Class")] 
    [DataContract]
 public partial class T_Class : INotifyPropertyChanging, INotifyPropertyChanged
 {
  
...

[Column(Storage="_F_ClassName", DbType="NVarChar(256)")]
        [DataMember]
  public string F_ClassName
  {
...

(3)修改svc文件,右击svc文件,选择打开方式-->HTML编辑器,增加Factory="System.ServiceModel.Activation.WebServiceHostFactory"

<%@ ServiceHost Language="C#" Debug="true" Service="Ajax_WCF.MyService" CodeBehind="MyService.svc.cs" Factory="System.ServiceModel.Activation.WebServiceHostFactory"%>



(4)修改web.config,找到以下节点(注:Ajax_WCF为项目的命名空间,因各自项目实际情况而异)

    

删除,换成

 
    
   

说明一下:(3),(4)二步是必须的,目的是为了生成Restful WCF,可以在ExtJs里用类似"MyService.svc/GetClsData"这样的url来访问

b.Extjs调用的前端页面

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="02.Grid.aspx.cs" Inherits="Ajax_WCF._02_Grid" %>



        
     
         
    
    ExtJs Basic Grid Demo




    ExtJs_Grid_Demo
    


ok,完成了。

 

另外,如果要实现对Grid的查询,可以再加上这几行代码:

JS部分:

 

var fnAjaxDemo = function() {
            var mydata;
            Ext.Ajax.request({
                url: "MyService.svc/GetClsData?name=" + encodeURIComponent(Ext.get("ProductName").dom.value), //服务器端地址
                success: function(request) {                   
                    store.loadData(eval(request.responseText));                   
                },
                failure: function() {
                    alert("failure!");
                }
            });
        }

        Ext.get("btnRefresh").on("click", fnAjaxDemo);

 

。。。

 

html部分:
分类名称:

当然,相应的GetClsData部分也要修改:

 

[OperationContract]
        [WebInvoke(ResponseFormat = WebMessageFormat.Json, Method = "GET", UriTemplate = "GetClsData")]
        public T_Class[] GetClsData()
        {
            string name = CNTVS.TOOLS.Utils.fRequest("name").ToString();
            List _Result = new List();
            using (DBDataContext db = new DBDataContext())
            {
                var query = db.T_Classes.Where(c => c.F_Type.ToLower() == "shop");

                if (name != "")
                {
                    query = query.Where(p => p.F_ClassName.ToLower().Contains(name.ToLower()));
                }

                var query2 = query.OrderBy(c => c.F_RootID).ThenBy(c => c.F_Orders).Select(c => new { F_ID = c.F_ID, F_ClassName = c.F_ClassName, F_ParentID = c.F_ParentID, F_Orders = c.F_Orders, F_ReadMe = c.F_ReadMe });

                _Result = db.ExecuteQuery(query2, true).ToList();
                db.Connection.Close();
            }
            return _Result.ToArray();
        }

最后说明几个注意事项:
1.Ext.onReady(function() {...}这一串script,如果直接写在页面中,必须放在...中,否则网格上右击,设置显示列时,报JS错误,原因不明。
2.WCF的服务端方法,必须设置成JSON格式,另外Method设置为GET,否则运行时,前端页面读不出数据
3.如果设置了autoExpandColumn,则autoExpandColumn对应的列,必须是id对应的列,否则出错
4.服务端的类中,如果有DateTime字符的字段,需要手动修改dbml对应的cs文件,把DateTime改成string,否则序列化时,会产生很怪的值,估计是.Net在序列化成JSON时的bug.
5.为了减少生成的JSON字符串的大小,可以仅在需要输出的类属性上标记[DataMember],这样在生成的JSON字符串,不会包含未标记为[DataMember]的字段

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/231687.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号