Extjs4 类的定义和扩展

2024-04-21 15:18
文章标签 定义 扩展 extjs4

本文主要是介绍Extjs4 类的定义和扩展,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一般定义方式,注意方法和函数的添加方式不同。(添加函数只能用override方式添加不知为什么,有知道的,请搞之。)

  1. 定义一个类,并给他一个方法

       1: Ext.define('Simple.Class',{
       2:     welcome:function(){
       3:         alert('Welcome to the app');
       4:     }
       5: });
  2. 使用Ext.override方法对已有类进行重载并添加函数

       1: Ext.override(Simle.Class,{
       2:     goodBye:function(){
       3:         alert('Goodbye');
       4:     },
       5:     funAll:function(){
       6:         this.welcome();
       7:         this.goodBye();
       8:     }
       9: });
  3. 实例化类对象,并调用新的方法

       1: var app = new Simple.Class();
       2: app.runAll();   //Welcome to the app     Goodbye
  4. 重载的另一种写法

       1: Simple.Class.override({
       2:    // New members...
       3: });

实际例子:

Ext.define('MyButton',{extend:'Ext.Action',initComponent: function(){var me = this;var initEnable = true;       //初始权限}
});Ext.override(MyButton,{mysetenable:function(b){   //增加自定义函数设置按钮权限if ( this.initEnable ) {if (b){this.enable();}else{this.disable();}}else{this.disable();}}	
});

例子2:

Ext.define('PO_Head_Add_Panel', {extend: 'Ext.form.Panel',alias: 'widget.PO_Head_Add_Panel',//height:400,//width:600,frame: true,layout: 'anchor',   //该form分为两列bodyPadding: 5,      //偏移5px//baseCls: "x-plain",  //指定使用系统背景色//defaults: { anchor: "95%", msgTarget: "side" },//   anchor: '100%',defaults:{//统一设置表单字段默认属性//autoFitErrors : false,//展示错误信息时是否自动调整字段组件宽度labelSeparator :':',//分隔符labelWidth : 60,//标签宽度//width : 150,//字段宽度allowBlank : false,//是否允许为空//blankText : '不允许为空', //若设置不为空,为空时的提示labelAlign : 'right',//标签对齐方式msgTarget :'qtip'          //显示一个浮动的提示信息//msgTarget :'title'       //显示一个浏览器原始的浮动提示信息//msgTarget :'under'       //在字段下方显示一个提示信息//msgTarget :'side'        //在字段的右边显示一个提示信息//msgTarget :'none'        //不显示提示信息//msgTarget :'errorMsg'    //在errorMsg元素内显示提示信息},items:[{xtype:'combobox',name: 'ToAddress',labelWidth:70,width:600,queryMode: 'local',store:TmpAddressStore,displayField: 'AddrName',valueField: 'AddrName',                editable : false,// 是否允许输入forceSelection : true,// 必须选择一个选项msgTarget: 'side',allowBlank: false,	//是否允许空值fieldLabel: '送货地址'},{xtype:'textfield',name: 'HRemark',labelWidth:70,width:600,msgTarget: 'side',allowBlank: false,	//是否允许空值fieldLabel: '备注'}],initComponent: function(){ var me = this;var PoType = '';       //可以定义属性   obj.PoType 使用var TmpHeadRec = Ext.create('PO_HeadData');  Ext.apply(this, {buttons: [{text: '保存',handler:function(){if (me.getForm().isValid()) {   //判断提交的数据是否符合正则表达式//保存功能}}}, {text: '取消',handler: function () { me.ownerCt.hide(); }            }],SetFormValue:function(){       //自定义方法  obj.SetFormValue() 方式调用me.TmpHeadRec = HeadStore.getAt(0);me.getForm().findField('POType').setValue(me.TmpHeadRec.get('POType'));me.getForm().findField('PONum').setValue(me.TmpHeadRec.get('PONum'));}});this.callParent(arguments);}    
});




这篇关于Extjs4 类的定义和扩展的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/923389

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

PHP7扩展开发之数组处理

前言 这次,我们将演示如何在PHP扩展中如何对数组进行处理。要实现的PHP代码如下: <?phpfunction array_concat ($arr, $prefix) {foreach($arr as $key => $val) {if (isset($prefix[$key]) && is_string($val) && is_string($prefix[$key])) {$arr[

PHP7扩展开发之字符串处理

前言 这次,我们来看看字符串在PHP扩展里面如何处理。 示例代码如下: <?phpfunction str_concat($prefix, $string) {$len = strlen($prefix);$substr = substr($string, 0, $len);if ($substr != $prefix) {return $prefix." ".$string;} else

PHP7扩展开发之类型处理

前言 这次,我们将演示如何在PHP扩展中如何对类型进行一些操作。如,判断变量类型。要实现的PHP代码如下: <?phpfunction get_size ($value) {if (is_string($value)) {return "string size is ". strlen($value);} else if (is_array($value)) {return "array si

PHP7扩展开发之依赖其他扩展

前言 有的时候,我们的扩展要依赖其他扩展。比如,我们PHP的mysqli扩展就依赖mysqlnd扩展。这中情况下,我们怎么使用其他扩展呢?这个就是本文讲述的内容。 我们新建立一个扩展,名字叫 demo_dep , 依赖之前的say扩展。 在demo_dep扩展中,我们实现demo_say方法。这个方法调用say扩展的say方法。 代码 基础代码 确保say扩展的头文件正确安装到了php

PHP7扩展开发之函数方式使用lib库

前言 首先说下什么是lib库。lib库就是一个提供特定功能的一个文件。可以把它看成是PHP的一个文件,这个文件提供一些函数方法。只是这个lib库是用c或者c++写的。 使用lib库的场景。一些软件已经提供了lib库,我们就没必要再重复实现一次。如,原先的mysql扩展,就是使用mysql官方的lib库进行的封装。 在本文,我们将建立一个简单的lib库,并在扩展中进行封装调用。 代码 基础

PHP7扩展开发之对象方式使用lib库

前言 上一篇文章,我们使用的是函数方式调用lib库。这篇文章我们将使用对象的方式调用lib库。调用代码如下: <?php $hello = new hello(); $result = $hello->get(); var_dump($result); ?> 我们将在扩展中实现hello类。hello类中将依赖lib库。 代码 基础代码 这个扩展,我们将在say扩展上增加相关代码。sa