您的位置:首页 > 其它

[转载]EXT核心API详解(二)-Array/Date/Function/Number/String

2009-05-15 11:05 519 查看
Array类

indexOf( Object o ) : Number

object是否在数组中,找不到返回-1;找到返回位置

remove( Object o ) : Array

从数组中删除指定的对象object,如果找不到object则数组无变化

Number类

constrain( Number min, Number max ) : Number

检查数值是否介于min与max之间, 如果大于max 返回max,如果小于min返回min, 否则返回当前值

String类

escape( String string ) : String

将string中的'和"替换为"' ""

format( String string, String value1, String value2 ) : String

格式化字符串,例:

var cls = 'my-class', text = 'Some text';

var s = String.format('<div class="{0}">{1}</div>', cls, text);// 结果 <div class="my-class">Some text</div>

leftPad( String string, Number size, [String char] ) : String

以char将string补齐为size长度,char默认定义空格

toggle( String value, String other ) : String

交换值,如果当前值等于value,则被赋值other,反之等于value,例:

sort = sort.toggle('ASC', 'DESC');

trim() : String

去除开头或结尾多余的空格

Date类

Date.parseDate( String input, String format ) : Date

将字符串string依指定的格式format转换为时间,其中格式定义详见format方法

例:dt = Date.parseDate("2006-01-15 3:20:01 PM", "Y-m-d h:i:s A" );

add( String interval, Number value ) : Date

增加时间段,String interval在Data类中已定义

Date.MILLI = "ms";

Date.SECOND = "s";

Date.MINUTE = "mi";

Date.HOUR = "h";

Date.DAY = "d";

Date.MONTH = "mo";

Date.YEAR = "y";

例var dt2 = new Date('10/1/2006').add(Date.DAY, -5);

between( Date start, Date end ) : Boolean

是否在两个指定的时间之间

clearTime( Boolean clone ) : Date

清除时间信息,如果clone为真,则克隆自已并返回新Date,本身的值并不改变,反之则修改自身的值

clone() : Date

克隆

format( String format ) : String

格式化时间

d 两位数的日期 01 至 31

D 三字母的星期名 Mon 至 Sun

j 一位数的日期 1 至 31

l 完整的星期名 Sunday 至 Saturday

S 日期的英文顺序刻词尾,两个字符 st, nd, rd or th.

w 一周中的第几天 0 (星期天) 至 6 (星期六)

z 一年中的第几天 0 至 364 (闰年365 )

W ISO-8601 星期数, 周一算一个星期的开始 1 至 53

F 月的完整英文名 January 至 December

m 月,以0前导 01 至 12

M 三字母的简写月名 Jan 至 Dec

n 月 1 至 12

t 本月有多少天 28 至 31

L 是否闰年 1/0

Y 完整的年份 例: 1999 或 2003

y 年的后两位 例: 99 或 03

a 上午/下午小写 am 或 pm

A 上午/下午大写 AM 或 PM

g 小时/12小时制 1 至 12

G 小时/24小时制 0 至 23

h 小时/12小时制 01 至 12

H 小时/24小时制 00 至 23

i 分钟 00 至 59

s 秒 00 至 59

u 毫秒 001 至 999

O 时区,与格林威治标准时间之差 例: +0200

T 时区简写 例: EST, MDT ...

Z 时区间距 -43200 至 50400

其中Date类内置了几种格式

Date.patterns = {

ISO8601Long:"Y-m-d H:i:s",

ISO8601Short:"Y-m-d",

ShortDate: "n/j/Y",

LongDate: "l, F d, Y",

FullDateTime: "l, F d, Y g:i:s A",

MonthDay: "F d",

ShortTime: "g:i A",

LongTime: "g:i:s A",

SortableDateTime: "Y-m-d""TH:i:s",

UniversalSortableDateTime: "Y-m-d H:i:sO",

YearMonth: "F, Y"

};

当然ISO8601Long和ISO8601Short还是非常招人喜欢的

例:

dt.format(Date.patterns.ISO8601Long);

dt.format('Y-m-d H:i:s');

getDayOfYear() : Number

一年中的第几天,从0开始

getDaysInMonth() : Number

本月有多少天,

getElapsed( [Date date] ) : Number

当前日期对象与date之间相差的毫秒数

getFirstDateOfMonth() : Date

本月的第一天

getFirstDayOfMonth() : Number

本月第一天是星期几

getGMTOffset() : String

时区信息(见格式定义中的'O')

getFirstDateOfMonth() : Date

本月最后一天

getFirstDayOfMonth() : Number

本月最后一天是星期几

getSuffix() : String

日期后导符(见格式定义中的S)

getTimezone() : String

时区(见T)

getWeekOfYear() : Number

一年中的第几周(见W)

isLeapYear() : Boolean

是否闰年

Function类

createCallback(/*args...*/) : Function

创建回叫方法

createDelegate( [Object obj], [Array args], [Boolean/Number appendArgs] ) :

创建委托

这两个记法除了传参方式不同,看不出有什么差异都是调用method.apply,createCallback可以看作一个简化版的createDelegate

createCallback==>return method.apply(window, args);

createDelegate==>return method.apply(obj || window, callArgs);

前者参数比较简单,直接传过去了,后者的规则比较复杂点,如果appendArgs为真,args将附加在参数列表之后,如果是数值,args将在参数列表的appendargs位置插入,其它情况下原参将不起作用

例:

var fn = func1.createDelegate(scope, [arg1,arg2], true)

//fn(a,b,c) === scope.func1(a,b,c,arg1,arg2);

var fn = func1.createDelegate(scope, [arg1,arg2])

//fn(a,b,c) === scope.func1(arg1,arg2);

var fn = func1.createDelegate(scope, [arg1,arg2], 1)

//fn(a,b,c) === scope.func1(a,arg1,arg2,b,c);

var fn = func1.createCallback(arg1, arg2);

//fn() === func1(arg1, arg2)

createCallback : function(/*args...*/)

createInterceptor( Function fcn, [Object scope] ) : Function

创建阻断方法,如果fcn返回false,原方法将不会被执行

createSequence( Function fcn, [Object scope] ) : Function

创建组合方法,执行原方法+fcn

defer( Number millis, [Object obj], [Array args], [Boolean/Number appendArgs] ):Number

定时执行,隔millis毫秒后执行原方法
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: