(一)、首先我们介绍一下Model类中比较常用的几个属性,如果我们想构建一个Model类,最主要的属性就是(Fields)属性,这个属性接受一个数组。用来设置Model中所包含的字段。定义的格式如下:
 
Ext.regModel("Student",{
 
   fields:[
 
{name:"name",type:"string"},
{name:"class",type:"string"}
   ]
});
 
(二)、在我们了解到怎么定义一个简单的Model,以及定义Model所需要的属性时。下面我们来看一下。Model类为我们提供了哪些比较好的功能。
 
    1、首先我们来看一下fields属性中的功能,例如:我们现在定义了一个如上的Model类,然后,数据源返回班级(class)这个属性时。格式为(1、2、3),如果我们把这样的数据呈现出来,那么将显示的很不友好。所以,我们要在呈现之前,对数据做一个转换。把原本不友好的数据,转换成有好的数据,这就用到了。fields中的convert属性。具体的代码如下(注意红色字体部分):
 
Ext.regModel("Student",{
 
   fields:[
 
{name:"name",type:"string"},
{name:"class",type:"string",convert:function(val){
 
if(val=="1"){return "一班"};
if(val=="2"){return "二班"};
if(val=="3"){return "三班"};
}}
   ]
});
 
通过上边的设置,我们就对数据做了相应的转换了,呈现到客户面前的不再是(1、2、3),这样我们的呈现就变得比较友好了。
 
 
    2、另外,在我们定义好一个Model类之后,我们就可以使用这个Model类。最简单的方式,我们是直接new一个Model类的对象,然后将我们的数据信息加载到对象中,有点类似于Ext3.X中的record的对象的使用。代码如下:
 
var student=new Student({
 
name:"Jerry",
 
class:"2"
 
});
 
上述代码我们根据Student的模型类,定义了一个该类的对象,但是,往往在我们的应用程序中,像这样的情况很少,毕竟我们的数据不一定都是这种一成不变的数据,有时候我们需要从后台加载我们的数据,然后给于我们的model类。这就需要我们的模型类有能够请求后台的能力,这也是Model中提供的第二个功能,Model中提供一个属性proxy(代理)。这个proxy中有几个比较重要的属性(type、url、reader),type属性值是一个字符串形式,用来表明。该代理的一种类型,具体的我们可以查看API中了解有哪些类型,url也就是请求后台的url、reader,也就是我们要用什么样的阅读器,来解析我们的数据,具体的,我们可以看一下。下边简单的例子:
 
Ext.regModel("Student",{
 
   fields:[
 
{name:"name",type:"string"},
{name:"class",type:"string",convert:function(val){
 
if(val=="1"){return "一班"};
if(val=="2"){return "二班"};
if(val=="3"){return "三班"};
}}
   ],
   proxy:{
 
type:"rest",
url:"data/1.aspx",
reader:"json"
 
   }
});
 
Student.load(001,{
 
success:function(student){
 
//处理加载完成的逻辑
}
});
 
1.aspx返回的数据格式:
 
{id:001,name:"zhangsan",class:"2"}
 
经过上述的设置,我们的Model就可以与后台交互,并要求后台返回我们想要的数据了,这个也是之前record类所办不到的。
 
 
    3、在我们的应用程序中,可能我们定义的Model不止一个。但是,他们之间可能都是独立的,没有任何的关系,但是,在我们的应用程序中可能在后台返回的数据中存在一定的联系,而且我们又想让这些Model之间存在一定的联系,这样我们在处理起来,会比较简单一些。大家看下边的一段数据。
 
{
id:"009",
name:"Jerry",
subjects:[
 
{id:"001",name:"English"},
 
{id:"002",name:"Mathematics"}
]
}
 
在上述的数据中,科目和学生之间是有一定的联系的。所以,我们也在想,解析数据的时候,让他们保持这种联系,以便于我们更好的解析数据。这样我们就用到了Model中的belongsTo和hasMany这样两个属性。首先要解析这样的数据,我们需要定义好我们的Model类。如下:
 
Ext.regModel("subject",{
 
fields:[
 
{name:"id",type:"string"},
{name:"name",type:"string"}
],
belongsTo:"Stdudent"
});
 
 
Ext.regModel("Student",{
 
fields:[
 
{name:"id",type:"string"},
{name:"name",type:"string"}
 
],
 
proxy:{
 
type:"rest",
url:"data/1.aspx",
reader:"json"
},
 
hasMany:[{model:"subject",name:"subjects"}]
 
});
 
注意“hasMany”和“belongsTo”的使用。
 
在我们定义好Model后,下面我们就可以加载并解析我们的数据了。
 
Student.load("009",{
 
success:function(student){
 
alert(student.get("id"));
 
alert(student.subjects().getCount());//我们可以直接访问该学生的科目
}
})
 
});
 
    4、另外在ExtJS4的Model中还提供了对字段列的验证功能。我们想验证字段只需要设置Model类的validations属性即可,代码如下:

Ext.regModel("Student",{

fields:[

{name:"id",type:"string"},

{name:"name",type:"string"}

],

proxy:{

type:"rest",

url:"data/1.aspx",

reader:"json"

},

hasMany:[{model:"subject",name:"subjects"}],

validations:[

{type:"presence",field:"id"},

{type:"length",field:"name",min:3}

]

});

var student=new Student({id:"001",name:"z"});

var stuvalidate=student.validate();//得到验证类

stuvalidate.isValid();//返回验证结果true或false

stuvalidate.each(function(error){

alert(error.field+" "+error.message);//遍历验证的信息

});

EXtJS Ext.data.Model的更多相关文章

  1. ExtJs Ext.data.Model 学习笔记

    Using a Proxy Ext.define('User', { extend: 'Ext.data.Model', fields: ['id', 'name', 'email'], proxy: ...

  2. [ExtJs] ExtJs4.2 数据模型Ext.data.Model学习

    Model代表应用程序管理的一些对象.例如,我们可能会为 我们想在系统中建模的现实世界中的一些物体像使用者.产品和汽车等定义一个Model.这些Model在 Ext.ModelManager中注册,被 ...

  3. ExtJS笔记 Ext.data.Model

    A Model represents some object that your application manages. For example, one might define a Model ...

  4. ExtJS教程(5)---Ext.data.Model之高级应用

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/jaune161/article/details/37391399 1.Model的数据验证 这里借助 ...

  5. ExtJs Ext.data.Store 处理

    var storeCpye = new Ext.data.GroupingStore({ proxy : new Ext.data.HttpProxy({ url : 'cxgl_cpye.app?d ...

  6. Extjs 项目中常用的小技巧,也许你用得着(5)--设置 Ext.data.Store 传参的请求方式

    1.extjs 给怎么给panel设背景色 设置bodyStyle:'background:#ffc;padding:10px;', var resultsPanel = Ext.create('Ex ...

  7. ExtJS笔记 Ext.data.Types

    This is a static class containing the system-supplied data types which may be given to a Field. Type ...

  8. 设置 Ext.data.Store 传参的请求方式

    设置 Ext.data.Store 传参的请求方式 1.extjs 给怎么给panel设背景色 设置bodyStyle:'background:#ffc;padding:10px;', var res ...

  9. 转: Ext.data.Store 修改Post请求

    Extjs 4.0版本 var Store = Ext.create('Ext.data.Store', { pageSize: pageSize, model: 'Ext.data.Model名称' ...

随机推荐

  1. 十一. Python基础(11)—补充: 作用域 & 装饰器

    十一. Python基础(11)-补充: 作用域 & 装饰器 1 ● Python的作用域补遗 在C/C++等语言中, if语句等控制结构(control structure)会产生新的作用域 ...

  2. 深入理解java虚拟机---Class文件(二十)

    无符号数.表 当实现了不同语言的编译器,比如jython,jruby等等,那么就可以利用这些语言编写代码,通过各自的编译器编译成符合jvm规范的字节码文件,就可以利用jvm来执行了. Class文件在 ...

  3. L267 How to save money

    When it comes to saving money, the struggle is all too real. It's like your bank account and your 20 ...

  4. day 71-72 cookie 和session

    拓展知识   request---->请求信息 属性: request.path       # 获取访问文件路径 request.method属性 #获取请求中使用的HTTP方式(POST/G ...

  5. day 28 hasattr getattr serattr delattr 和带__内置__ 类的内置方法

    反射 后边有关字符串的# class Management:# role = '管理员'# def __init__(self,name,sex,phone,mail):# self.name = n ...

  6. win7 java环境变量配置

    进行win7下Java环境变量配置      在"系统变量"下进行如下配置: (1)新建->变量名:JAVA_HOME变量值 C:\Program Files\Java\jd ...

  7. os.path和sys.path的区别

    os.path是module,包含了各种处理长文件名(路径名)的函数. sys.path是由目录名构成的列表,python从中查找扩展模块(python源模块)编译模块,或者二进制扩展),启动pyth ...

  8. python day02作业

  9. Python 封装

    # 封装: # 1. 对属性的封装 # 2. 对功能的封装 # 3. 模块 # 4. 包 class Student: def __init__(self, num, name, clazz): se ...

  10. 使用python绘出常见函数

    '''''' ''' mpl.rcParams['font.sans-serif'] = ['SimHei'] mpl.rcParams['axes.unicode_minus'] = False用来 ...