当前位置: 首页 > news >正文

Ts基础

 //typeof 用来判断变量类型
        var s: string = 'egret';
        var isString: boolean = typeof s === 'string';
        console.log(typeof s === 'string');
        console.log(typeof s === 'number');
        console.log(typeof s === 'any');
        console.log(typeof s === 'array');
        //instanceof 用来判断方法或者接口类型
        var a: A = new A();
        console.log(a instanceof A);
        console.log(a instanceof B);

  TS用any类型对比as3里的动态object类型

TS参考手册:http://www.runoob.com/manual/gitbook/TypeScript/_book/

 private box:any;
    //用any代表Object类型
    private obj:any = {};
    private obj2:Object;

    constructor(){
        Laya.init(600,400);
        Laya.Stat.show(0,0);

        this.box = {height: 5, width: 6, scale: 10};
        this.box.isRect = true;
        for(var i in this.box){
            console.log(i);
        }

        this.obj = new Object();
        this.obj.name = "zhagnsan";
        this.obj.pass = "123456";

        this.obj2 = {};
        this.obj2['name'] = "lisi";
        this.obj2['pass'] = "12341563";
        Laya.stage.on("click",this,this._click);
    }

 数组克隆

https://www.cnblogs.com/matthew-2013/p/3524297.html

var actors:string[]=["张三","李四","王五","赵六"];
var a2 = actors.slice(0);
console.log(actors);
a2[0]="张三三";
console.log(a2);
console.log(actors);
///
[张三, 李四, 王五, 赵六]
[张三三, 李四, 王五, 赵六]
[张三, 李四, 王五, 赵六]
数组克隆可以用slice(0);
使用slice() 或者 concat()来实现一维数组的深拷贝,但这种方法只适用于一维数组,对多维数组无效。
http://bbs.csdn.net/topics/380189488

for of不能遍历对象,请改成for in

var sum:number = 0;
            for(var key in dict)
            {
                console.log(dict[key]);
                sum+= dict[key];
            }
 

sort() 方法用于对数组的元素进行排序。语法如下:

arrayObject.sort(sortby)

返回值为对数组的引用。请注意,数组在原数组上进行排序,不生成副本。

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
若 a 等于 b,则返回 0。
若 a 大于 b,则返回一个大于 0 的值。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
function NumAscSort(a,b)
{
  return a - b;
}
function NumDescSort(a,b)
{
  return b - a;
}
var arr = new Array( 3600, 5010, 10100, 801);
arr.sort(NumDescSort);
alert(arr);
arr.sort(NumAscSort);
alert(arr);

sort(fun)接受了个排序规则函数,这个函数将比较2个数字的大小。而我们的对象数组排序,实际上原理也是一样的。
如果不比较数字的大小,则可以这样:

?
1
2
var myarray=[ "Apple" , "Banana" , "Orange" ]
myarray.sort()

数组直接调用sort()后,数组按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。

 

对于对象数组排序,我们先写一个构造比较函数的函数:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//by函数接受一个成员名字符串做为参数
//并返回一个可以用来对包含该成员的对象数组进行排序的比较函数
var by = function (name){
  return function (o, p){
    var a, b;
    if ( typeof o === "object" && typeof p === "object" && o && p) {
      a = o[name];
      b = p[name];
      if (a === b) {
        return 0;
      }
      if ( typeof a === typeof b) {
        return a < b ? -1 : 1;
      }
      return typeof a < typeof b ? -1 : 1;
    }
    else {
      throw ( "error" );
    }
  }
}

要排序的数组:

?
1
2
3
4
5
var employees=[]
employees[0]={name: "George" , age:32, retiredate: "March 12, 2014" }
employees[1]={name: "Edward" , age:17, retiredate: "June 2, 2023" }
employees[2]={name: "Christine" , age:58, retiredate: "December 20, 2036" }
employees[3]={name: "Sarah" , age:62, retiredate: "April 30, 2020" }

直接调用函数:

?
1
employees.sort(by( "age" ));

到这里,对象数组排序就算基本实现了。那如何实现多个键值排序呢?意思就是先是对age排序,如果age相同,再比较name。
这时,我们可以进一步修改by函数,让其可以接受第二个参数,当主要的键值产生一个匹配的时候,另一个compare方法将被调用以决出高下。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
//by函数接受一个成员名字符串和一个可选的次要比较函数做为参数
//并返回一个可以用来包含该成员的对象数组进行排序的比较函数
//当o[age] 和 p[age] 相等时,次要比较函数被用来决出高下
var by = function (name,minor){
  return function (o,p){
    var a,b;
    if (o && p && typeof o === 'object' && typeof p === 'object' ){
      a = o[name];
      b = p[name];
      if (a === b){
        return typeof minor === 'function' ? minor(o,p):0;
      }
      if ( typeof a === typeof b){
        return a < b ? -1:1;
      }
      return typeof a < typeof b ? -1 : 1;
    } else {
      thro( "error" );
    }
  }
}
 
employees.sort(by( 'age' ,by( 'name' )));

好了,现在可以放心使用了。如果看不懂,可直接copy 这个by函数到你的应用里面,直接调用即可。

转载于:https://www.cnblogs.com/as3lib/p/7807620.html

相关文章:

  • SVN “不能打开文件“.svn/lock” 权限不够”精解
  • Oracle动态SQL和静态SQL比较
  • Android学习笔记--Content Provider 1
  • SpringMVC 参数注入
  • 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】下 ~ Net程序员的福利...
  • IIS6.0 + openssl执行版 + Windows2003 -- 移植篇
  • 【基础】ARP协议-交换机工作原理-及广播风暴问题分析
  • 【原创】机器学习之PageRank算法应用与C#实现(2)球队排名应用与C#代码
  • 算法之【大整数乘法】
  • 编程语言影响人的思维(2
  • 使用Rancher-Gen动态更新配置文件
  • 限制Apache日志access.log文件大小
  • ntop安装过程
  • ln命令解析_学习笔记
  • 利用软硬件逻辑等价原理模拟VMware硬件环境
  • [Vue CLI 3] 配置解析之 css.extract
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 【技术性】Search知识
  • Android Volley源码解析
  • Android系统模拟器绘制实现概述
  • Computed property XXX was assigned to but it has no setter
  • HTTP请求重发
  • maven工程打包jar以及java jar命令的classpath使用
  • Redis 中的布隆过滤器
  • Sequelize 中文文档 v4 - Getting started - 入门
  • swift基础之_对象 实例方法 对象方法。
  • 多线程 start 和 run 方法到底有什么区别?
  • 服务器之间,相同帐号,实现免密钥登录
  • 工程优化暨babel升级小记
  • 将 Measurements 和 Units 应用到物理学
  • 那些年我们用过的显示性能指标
  • 排序(1):冒泡排序
  • 前端面试之闭包
  • 运行时添加log4j2的appender
  • MiKTeX could not find the script engine ‘perl.exe‘ which is required to execute ‘latexmk‘.
  • 【干货分享】dos命令大全
  • Java数据解析之JSON
  • ![CDATA[ ]] 是什么东东
  • #HarmonyOS:Web组件的使用
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (C#)获取字符编码的类
  • (PWM呼吸灯)合泰开发板HT66F2390-----点灯大师
  • (Redis使用系列) Springboot 实现Redis消息的订阅与分布 四
  • (翻译)terry crowley: 写给程序员
  • (附源码)spring boot校园健康监测管理系统 毕业设计 151047
  • (论文阅读23/100)Hierarchical Convolutional Features for Visual Tracking
  • (每日持续更新)jdk api之FileFilter基础、应用、实战
  • (三分钟了解debug)SLAM研究方向-Debug总结
  • (原創) 如何安裝Linux版本的Quartus II? (SOC) (Quartus II) (Linux) (RedHat) (VirtualBox)
  • (转)es进行聚合操作时提示Fielddata is disabled on text fields by default
  • ***监测系统的构建(chkrootkit )
  • ../depcomp: line 571: exec: g++: not found
  • .bat批处理(六):替换字符串中匹配的子串
  • .gitignore
  • .Net CF下精确的计时器