【翻译】EXTJS 编码风格指南与实例

原文:EXTJS Code Style Guide with examples

Ext JS风格指南:

  • 熟知的且易于学习
  • 快速开发,易于调试,轻松部署
  • 组织良好、可扩展和可维护

Ext JS应用程序的命名约定:

1、类

类名应使用驼峰命名(CamelCased)。
不要使用下划线,或其他连接字符。
如:MyCustomClass

不是通过Sencha分发的类,永远不要使用Ext作为顶层命名空间。
在类名中,应至少使用一次点号来划分命名空间。
如TopLevelNamespace.MyClassName

顶层命名空间和实际类名应使用驼峰命名,而其他则应使用小写字母。
//好的类名
如:TopNamespace.midlevelnamespace.MyCustomClass
如:MyModule.view.UserGrid
//坏的类名
eg:MyCompany.useful_util.Debug_Toolbar

2、使用命名空间来分组相关的组件

命名空间应基于目录结构构建。目录应基于功能化的业务组件将组件分组为逻辑模块。这意味着维护用户可根据命名空间和组件啦管理组件:

目录结构:
MyModule/controller/UserController.js
MyModule/store/UserStore.js
MyModule/model/UserModel.js
MyModule/view/UserGrid.js
MyModule/view/UserForm.js

类名:
MyModule.controller.UserController
MyModule.store.UserStore
MyModule.model.UserModel
MyModule.view.UserGrid
MyModule.view.UserForm

3、Ext JS的组件和控件

所有组件都应使用3个小写字母作为前缀,之后适当使用每一个单词(如txtFirstName, cboDisplay, dtmStartDate)。

Form Panel = frm
Text Field = txt
Combo Box = cbo
Button = btn
Label = lbl
Check Box = chk
Date Field = dtm
Number Field = num
Grid = grd
Tab Panel = tab
Tab Page = pge
Panel = pnl
Container = con
Toolbar = tlb
Paging Toolbar = pgt

每一个Sencha组件都应当将itemId设置为控件的名称。使用驼峰命名来为itemId命名(如txtFirstName)。
如:itemId : txtFirstName

4、变量、常量、私有变量、属性和方法:

A. 变量应总是使用驼峰命名。

如:
var isGoodName;
var base64Encoder;
var thisIsMyName;
var base64Encoder

B. 常量应使用大写字母

如:
 var SALARY = 1000;
 var MAX_COUNT = 10;
    var URL = "http://www.mydomain.net/";

C. 私有变量应以“_”开始

如: var _modelRecord;
 var _get = Ext.data.Model.prototype.get;
    var _set = Ext.data.Model.prototype.set;
    var val = _get.apply(this, arguments); // private variable used in thisway

D. 属性应总是使用驼峰命名。静态属性应使用大写字母。

如1:
Ext.MessageBox.YES = "Yes";
MyCompany.alien.Math.PI = "4.13";
如2:
/**@property {String} MASK_MESSAGE_SAVING_FORM Mask message for Saving form*/
    MASK_MESSAGE_SAVING_FORM: ‘Saving form data, please wait...‘,

E. 方法:方法应总是使用驼峰命名。这也适用于首字母缩写词。

如:
可接受的方法名称:
encodeUsingMd5()
getExtComponentByReference()
getHtml() instead of getHTML()
getJsonResponse() instead of getJSONResponse()
parseXmlContent() instead of parseXMLContent()

5. 公共基类要加注释文档

一个组件如何被用来作为其他组件的共同祖先,它就应当被放置咋爱common目录。
如:
/**
 * @class Common.CommonFunctions  
 * @author Sencha User
 *  
 * 该文件包含公共功能,可被用于任何Ext JS应用程序
 *
 *
 */
Ext.define(‘Common.CommonFunctions‘, {});

6、为方法添加注释文档

如:
/**
 * This will return an ExtJs component based on a reference
 * to that component.  This reference can either be the component
 * itself or the comopnent‘s id.
 * @param {String/Object} ref A reference to an ExtJs component, can either be the the components id or the component itself
 * @return {Object}
 */
function getExtComponentByReference(ref){
 var component;
 if (typeof ref === ‘string‘){
  component = Ext.getCmp(ref);
 } else if (typeof ref === ‘object‘){
  component = ref;
 } else {
  return false;
 }
 return component;
}

7. 为控制器的方法添加注释文档

如:
    /**
     * Function to provide logic to validate a BPM form prior to submitting it.
     * Override this method in your own custom controller to add form specific submit validation.
     * Note:  By default this function will simply call form.isValid() to determine if form is valid.
     *
     * @returns {boolean} If the form is valid for submit or not
     */
    isBPMFormValidForSubmit: function(){
     return this.getBpmForm().isValid();
    },

8、全局引用:

// 注意: 要指定他们使用的地方
   var globalPreferedMode = false;
   var globalUserPreferenceArr = [];  // Array used to compare with preference cols of trade grid while applying preferences

9、要为组件和控制器内为任何用户定义的配置项添加注释文档

如:

/**
  * @cfg {Number} headerColumns
  * The total number of columns to create in the table for this layout. If not specified, all Components added
  * to this layout will be rendered into a single row using one column per Component.
  */
 headerColumns: 6,
 
 /**
  * @cfg {Object/Object[]} headerFields
  * A single item, or an array of child Components to be added to this container.
  */
 headerFields: [],
 
  /** @readonly */
    isWindow: true,

/** @cfg {String} title The default window‘s title */
    title: ‘Title Here‘,

/** @cfg {Object} bottomBar The default config for the bottom bar */
    bottomBar: {
        enabled: true,
        height: 50,
        resizable: false
    },

/**
  * @cfg {String} store (required)
  * The key of the store to be used to back this form.
  */
 store: ‘‘

10、最佳实践:使用scope(作用域)

如:

getPeople :function(people){
 Ext.Ajax.request({
    url: ‘people.php‘,
    method : ‘GET‘,
    params: {
        id: 1,
        name:‘test‘
    },
    scope: this,
    success: this.onAfterGetPeople
 });
},

onAfterGetPeople:  function(response){
        //Dp some stuff
        var jsonData = Ext.decode(response.responseText);
        // process server response here
        this.getDepartments(jsonData,departments);
},
getDepartments : function(departments){
  Ext.Ajax.request({
      url: ‘departments.php‘,
      method : ‘GET‘,
      params: departments,
      scope: this,
      success: this.onAfterGetDepartments
   });
},
onAfterGetDepartments : function(response){
 //DO more work
}

11、最佳实践:正确缩进和优化代码

如:
segmentContactModule :function(segButton,button,pressed){

var contactListStore = Ext.getStore(‘ContactListStore‘).
  contactView      = this.getContactView(),
  contactList      = contactView.query(‘#listContactItemsId‘)[0],
  contactDetailView= this.getContactDetailView(),
  selectedRecords  = contactList.getSelection(),
  buttonText    = button.getText();

contactListStore.clearFilter();
 
 if(pressed) {
   if(contactListStore.getCount() == 0){
    contactDetailVIew.setActiveItem(0);
   }else{

if(selectedRecords.length>0){
     this.contactListItemEvent(null,null,null,selectedRecords[0]);
    }else{
     contactDetailView.setActiveItem(0);
    }
   }
 }
 else{
  if(selectedRecords.lenght>0){
    this.contactListItemEvent(null,null,null,selectedRecords[0]);
  }
 }
} // end of method

12、最佳实践:总是让代码具有可读性

如:
if(!this.isReadable()){
 this.refactorWith({
  properIndentation : true,
  optimizedCodeReadability: true

});
}else{
 this.beHappy();
}

13、最佳实践:方法的返回类型

eg:
testSomeVal : function(someVal){
 return (someVal <=2); //添加括号提高可读性
}

14、最佳实践:

延迟初始化 - 只在必要时添加条目或视图
延迟渲染 - 节省浏览器时间
重用某些东西 - 节省开发时间

15、最佳实践 : 针对this的两个规则

当一个函数通过var引用来执行时,默认的执行上下文(this)是window
如:
var myFn = function(){
 console.log(this);
};
myFn();

当一个函数通过一个对象的键值来执行时,执行上下文(this)是object
如:
 var member = {
  name: ‘Eric‘,
     getName: function(){
   console.log(this);     
  }
 };
member.getName();

混合:
如:
var getName = member.getName;
getName();

如:
var member1 = {
  name: ‘Eric‘,
     getName: function(){
   console.log(this);     
  }
 };
var member2 = {
  name: ‘Bob‘,
     getName: member1.getName
 };
member2.getName();

【翻译】EXTJS 编码风格指南与实例

时间: 2024-10-10 14:29:00

【翻译】EXTJS 编码风格指南与实例的相关文章

【翻译】Ext JS——高效的编码风格指南

原文:ExtJS - Efficient coding style guide 作者:Raja 切勿使用"new"关键字:在Ext JS中,使用"new"关键字来创建一个组件或类的实例是一种错误的做法,因为这没有遵循组件的生命周期.应该使用Ext.create方法来创建对象,例如: 错误: var obj = new Ext.panel.Panel(); 正确: var obj = Ext.create('Ext.panel.Panel'); 初始化直接量:不要直接

(转)PEP 8——Python编码风格指南

PEP 8--Python编码风格指南标签(空格分隔): Python PEP8 编码规范原文:https://lizhe2004.gitbooks.io/code-style-guideline-cn/content/python/python-pep8.html https://python.freelycode.com/contribution/detail/47------PEP8中文版 -- Python编码风格指南(上,中,下) https://python.freelycode.c

来自 Google 的 R 语言编码风格指南

本文转自Xiao Nan的博客 R语言是一门主要用于统计计算和绘图的高级编程语言. 这份 R 语言编码风格指南旨在让我们的 R 代码更容易阅读.分享和检查. 以下规则系与 Google 的 R 用户群体协同设计而成. 概要: R编码风格约定 文件命名: 以 .R (大写) 结尾 标识符命名: variable.name, FunctionName, kConstantName 单行长度: 不超过 80 个字符 缩进: 两个空格, 不使用制表符 空白 花括号: 前括号不折行写, 后括号独占一行 赋

JavaScript 编码风格指南

A.1  缩进 // 4个空格的层级缩进 if (true) { doSomething(); } A.2  行的长度 // 每行限于80个字符,超出则在运算符后换行,缩进2个层级(8个空格) doSomething(argument1, argument2, argument3, argument4, argument5); A.3  原始值 // 字符串使用双引号及长字符串的链接 var name = "Nicholas", longStr = "this is a lo

R 语言编码风格指南

R 语言是一门主要用于统计计算和绘图的高级编程语言.这份 R 语言编码风格指南旨在让我们的 R代码更容易阅读.分享和检查.以下规则系与 Google 的 R 用户群体协同设计而成. 概要: R编码风格约定 文件命名: 以 .R (大写) 结尾 标识符命名: variable.name, FunctionName, kConstantName 单行长度: 不超过 80 个字符 缩进: 两个空格, 不使用制表符 空白 花括号: 前括号不折行写, 后括号独占一行 赋值符号: 使用 <-, 而非 = 分

JavaScript编码风格指南(中文版)

前言:程序语言的编码风格对于一个长期维护的软件非常重要,特别是在团队协作中.如果一个团队使用统一规范的编码分风格,可以提高团队的协作水平和工作效率.编程风格指南的核心是基本的格式化规则,这些规则决定了如何编写高水准的代码.本指南来自于<编写可维护的JavaScript>这本书,基于"Java语言编码规范"和Crockford的JavaScript编程规范,还有Nicbolas的一些个人经验和喜好.写作本文旨在加深自己印象,也为了更多人的了解到JS编码风格,提高自己的编码质量

PHP编码风格指南 (PHP-FIG PSR-2)

本指南是 PSR-1 基本编码标准 的扩展. 本指罗列了通用的PHP代码格式规则和建议,意在减少不同作者的编码风格差异带来的认知障碍. 这里的风格约定衍生自若干成员项目.指南作者们在多个项目中协作,推动了这些指导条款落地. 指南的关键在于共享,而不是规则本身. 文中涉及的关键词 "MUST 必须", "MUST NOT 必须不", "REQUIRED 必需", "SHALL 会", "SHALL NOT 不会&quo

[CoffeeScript]编码风格指南

?? 这份指南阐述了一些 CoffeeScript 的最佳实践和编码惯例. 这份指南是社群驱动的,非常鼓励大家来贡献内容. 请注意这还是一份正在完善的指南:仍有很多地方可以改进,有些已制定的准则也不一定是社区惯用的(基于此,在适当的情况下,这些有待斟酌的准则将有可能被修改或删除.) 灵感 本指南中的很多细节受到了几份现有的风格指南和其他资源的启发.特别是: PEP-8: Style Guide for Python Code Bozhidar Batsov's Ruby Style Guide

《编写可维护的 Javascript》读书笔记(附录 A 部分):Javascript 编码风格指南(1)原始值

记录一下比较有用的编码规范(该指南是基于 Java 语言编码规范和 Javascript 编程规范,同时结合作者 Nicholos Zakas 的个人经验和喜好). 一些关于格式(包括缩进.行的长度.运算符间距.括号间距.对象直接量.注释.单行注释.多行注释等类似的规范)的规范这里不做记录. A.3 原始值 // 好的写法 var name = "Nicholos"; // 不好的写法:单引号 var name = 'Nicholos'; // 不好的写法:字符串结束之前换行 var