Ext.js4.2.1中Ext.define有什么用

这篇文章给大家分享的是有关Ext.js4.2.1中Ext.define有什么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

为海北州等地区用户提供了全套网页设计制作服务,及海北州网站建设行业解决方案。主营业务为做网站、成都网站设计、海北州网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

一:描述

define(String className, Object data, Function createdFn): Ext.Base
define方法最多接受3个参数,className(类的名字),data(Object对象),createdFn(回调函数)
常用于 定义一个类,覆盖一个类 或者扩展一个类的属性或方法。

二:方法讲解

  1. Ext.define("Person", {

  2.             config : {

  3.                 Name : '',

  4.                 Age : 0

  5.             },

  6.             Say : function(msg) {

  7.                 Ext.Msg.alert(this.Name + " Says:", msg);

  8.             },

  9.             constructor : function(config) {

  10.                 this.initConfig(config);

  11.             }

  12.         });

  13.         Ext.define("Animal", {

  14.             Sing : function() {

  15.                 Ext.Msg.alert("Sing", "lalalalalallalalal");

  16.             }

  17.         });

  18.         Ext.define("MyApp.Developer", {

  19.             extend : 'Person',

  20.             mixins : {

  21.                 canSing : 'Animal'

  22.             },

  23.             alias : 'Developer',

  24.             requires : [],

  25.             config : {},

  26.             Coding : function(code) {

  27.                 Ext.Msg.alert(this.Name + " coding", code);

  28.             },

  29.             statics : {

  30.                 test : function(msg) {

  31.                     return "Test " + msg;

  32.                 }

  33.             }

  34.         });

  35.         var Alex = Ext.create("Developer", {

  36.             Name : "Alex",

  37.             Age : 26

  38.         });

  39.         Alex.setAge(33);

  40.         alert(Alex.getAge());

  41.         alert(MyApp.Developer.test('any way!'));

  42.         Alex.Sing();

  43.         Alex.Coding("int i=1;");



1.config
配置项,会调用this.initConfig(config)将配置项初始化,每个配置项自动生成4个函数:get,set,reset,apply 

2.extend
 用于类的继承

3.mixins  
类的混合,和Ext.override 类似。但它不会像override 那样,覆盖原有的功能。

4.alias
类的别名

5.requires
ExtJS4的requires是新增的机制,主要是实现异步加载机制。这样在不点击对应的按钮或者选项的时候就不会加载对应的js文件,提高了加载速度和用户等待时间。 
requires机制的实现通过一个Ext.Loader.setConfig函数来设置文件寻找的映射目录,然后在需要用到对应js文件的时候使用Ext.require进行加载。 

6.statics
可以在类中定义静态的方法



三:其它

1.Ext.apply(object,config,[defaults]):Object

该方法包含三个参数,第一个参数是要拷贝的目标对象,第二个参数是拷贝的源对象,第三个参数是可选的,表示给目标对象提供一个默认值。可以简单的理解成把第三个参数(如果有的话)及第二个参数中的属性拷贝给第一个参数对象

2.Ext.applyIf(object,config):Object

功能跟apply一样,只是不会拷贝那些在目标对象及源对象都存在的属性

感谢各位的阅读!关于“Ext.js4.2.1中Ext.define有什么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!


分享文章:Ext.js4.2.1中Ext.define有什么用
分享URL:http://scyanting.com/article/iiephh.html