《JavaScript高级程序设计》读书笔记--(3)引用类型

ECMAScript从技术来说是一门面向对象的语言,但不具备传统的面向对象语言所支持的类和接口等基本结构。虽然引用类型与类看起来类似,但是他们并不是相同的概念。引用类型有时也被成为对象定义,因为它描述的是一类对象所具有的属性和方法。

Object类型

创建Object实例的方式有两种。第一种是使用new操作符后跟Object构造函数;另一种是使用对象字面量表示法。也就是说new Object()等价于{},示例代码如下所示:

//使用new操作符后跟Object()方式
var person=new Object();
person.name=‘binghuojxj‘;
person.age=29;
//使用对象字面量方法
var car={
    name:‘BMW‘,
    Num:4
        };
//访问对象的属性也可以使用方括号表示法
alert(‘person.age=‘+person["age"]+‘\r\n‘+‘car.name=‘+car["name"]);

输出结果如下所示:

Array类型

ECMAScript中的数组与其它多数语言的的数组有着相当大的不同。具体特点如下:

  1. 数组是数据的有序列表但是数组每一项可以保存任何类型的数据;

  2. 数组的大小是可以动态调整的。

创建数组的方式有两种:使用Array构造函数和数组字面量表示法。示例代码如下所示:

//直接使用Array构造函数,传递数组元素个数参数
var colors=new Array(4);
//直接使用Array构造函数,传递数组元素
var nums=new Array(‘34‘);
//直接使用Array构造函数,可以不加new操作符
var names=Array(‘jxj‘,‘wsc‘,‘my‘);
//使用数组字面量表示法
var types=[‘Number‘,‘String‘,‘Undefined‘,‘Null‘,‘Object‘,‘Boolean‘];

ECMAScript数组提供了表现像栈一样(是一种后进先出的数据结构,简称为LIFO),对应的方法分别是push()方法和pop()方法。push()方法可以接受任意数量的参数,把它们逐个添加到数组末尾,并返回修改后数组的长度;而pop()方法则从数组末尾移除最后一项,减少数组的length值,返回被移除的项。与栈对应的数据结构是队列(队列在末端添加数据,从前端删除数据),实现操作的方法是push()方法和shift()方法。push()方法同上,shift()方法则从数组开始移除第一项,减少数组的length值,返回被移除的项。示例代码如下所示:

var names=[‘jxj‘,‘lhy‘,‘my‘];
//通过push方法向数组末尾添加一项
var currentLength=names.push(‘mht‘);
alert(‘当前数组长度:‘+currentLength);
//通过pop方法向删除数组末尾一项
var delVal=names.pop();
alert(‘当前数组元素:‘+names+‘被删除元素‘+delVal);
//通过shift方法删除数组第一项
delVal=names.shift();
alert(‘当前数组元素:‘+names+‘被删除元素‘+delVal);
//通过unshift方法在开始添加任意项并返回修改数组的长度
currentLength=names.unshift(‘lrp‘,‘zy‘);
alert(‘当前数组长度:‘+currentLength);
alert(names);

数组操作中经常要用到定义某一元素在数组中的位置,这对应两个位置的方法:indexOf()和lastindexOf()。其中indexOf()方法从数组的开始位置(位置0)开始向后查找,而lastIndexOf()方法从数组的末尾开始向前查找。要查找的项必须符合全等的条件(===),若没有找到符合的项目方法均返回-1。示例代码如下所示:

var numbers=[1,2,3,4,5,4,3,2,1,0];
//测试indexof方法
alert(numbers.indexOf(3));
//测试lastindexof方法
alert(numbers.lastIndexOf(3));
//测试元素不存在的情况
alert(numbers.indexOf(7));

Date类型

下面是创建Date对象的4种方式,如下代码所示:

var d = new Date();
var d = new Date(milliseconds);
var d = new Date(dateString);
var d = new Date(year, month, day, hours, minutes, seconds, milliseconds);

若要显示当前日期,使用“2014-09-03 15:12:24”格式,对应的代码如下:

function CurentTime()
    {
        var now = new Date();
        var year = now.getFullYear();      //年
        var month = now.getMonth() + 1;     //月
        var day = now.getDate();            //日
        var hh = now.getHours();            //时
        var mm = now.getMinutes();          //分
        var second=now.getSeconds()         //秒

        var clock = year + "-";
        if(month < 10)
            clock += "0";
        clock += month + "-";
        if(day < 10)
            clock += "0";
        clock += day + " ";
        if(hh < 10)
            clock += "0";
        clock += hh + ":";
        if (mm < 10) clock += ‘0‘;
        clock += mm+":";
        if (second < 10) clock += ‘0‘;
        clock += second;
        return clock;
    } 

因为Date对象的方法比较多,因此使用Date对象的方法时要特别注意方法返回的值的范围。Javascript中Date方法与C#种方法区别较大,注意方法返回值的范围,进而转化为日常使用的格式。

Function类型

函数的内容较多,下面将需要理解的要点全部列出来:

  1. 函数是对象,每个函数其实都是Function类型的实例;
  2. 函数名实质上是指向函数的一个指针。函数名为指针,函数名后加()表示调用函数;
  3. 函数没有重载;
  4. 函数名本身就是变量,所以函数可以作为值来使用;
  5. 函数内部agruments对象的callee属性指向拥有agruments对象的指针;
  6. 函数有两个非继承而来的方法apply()和call(),这个可以扩充函数赖以生存的作用域;
  7. 函数的prototype属性在实现自定义引用类型和继承时具有重要作用;
时间: 2024-11-08 21:30:21

《JavaScript高级程序设计》读书笔记--(3)引用类型的相关文章

Javascript高级程序设计读书笔记(第六章)

第6章  面向对象的程序设计 6.2 创建对象 创建某个类的实例,必须使用new操作符调用构造函数会经历以下四个步骤: 创建一个新对象: 将构造函数的作用域赋给新对象: 执行构造函数中的代码: 返回新对象. 构造函数的问题:每个方法都要在每个实例上重新创建一遍: 理解原型对象: 无论何时,只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象.默认情况下,所有原型对象都会自动获得一个constructor属性,这个属性包含一个指向proto

JavaScript高级程序设计-读书笔记(2)

第6章 面向对象的程序设计 创建对象 1.最简单方式创建Object的实例,如 var person = new Object(); person.name = “Greg”; person.age = 27; person.job = ”Doctor”; person.sayName = function() { alert(this.name); }; person. sayName(): 缺点:会产生大量重复代码 2.工厂模式:用函数来封装以特定接口创建对象的细节,如 function c

javascript高级程序设计读书笔记2

<!DOCTYPE HTML>//这个网页的文档类型,这个是html5的写法Bootstrap使用的某些HTML元素和CSS属性需要文档类型为HTML5 doctype.因此这一文档类型必须出现在项目的每个页面的开始部分 <html lang="en">//这里的lang="en"可以删除,如果不删除的,用谷歌之类打开,它会认为是英文的,会自动给翻译(如果设置了自动翻译的话) 有两个版本的 jQuery 可供下载:Production ver

JavaScript高级程序设计-读书笔记(6)

第20章 JSON JSON是一个轻量级的数据格式,可以简化表示复杂数据结构的工作量 JSON的语法可以表示一下三种类型的值 l        简单值:使用与JavaScript相同的语法,可以在JSON中表示字符串.数值.布尔值和null.但JSON不支持JavaScript中的特殊数值undefined. “Hello world!” l        对象(属性的值可以是简单值,也可以是复杂类型值,如下这样在对象嵌入对象) { “name” : ”Nicholas”, “age” : 29

JavaScript高级程序设计读书笔记之OOP

关于JavaScript创建对象的方式: 1.工厂模式 1 function createPerson(name, age, job){ 2 var o = new Object(); 3 o.name = name; 4 o.age = age; 5 o.job = job; 6 o.sayName = function(){ 7 alert(this.name); 8 }; 9 return o; 10 } 11 var person1 = createPerson("Nicholas&qu

javascript高级程序设计 读书笔记2

第五章 引用类型 对象是引用类型的实例,引用类型是一种数据结构,将数据和功能组织在一起.描述的是一类对象所具有的属性和方法.对象是某个特定引用类型的实例,新对象是使用new操作符后跟一个构造函数俩创建的,构造函数本身就是一个函数,只不过该函数试处于创建新对象的目的而定义的.  eg:    var person = new Object(); 1.创建Object实例的方式有两种   一:new+Object 二:对象字面量 var person = new Object(); var pers

JavaScript高级程序设计-读书笔记(4)

第11章 DOM扩展 1.选择符API Selector API Level 1 的核心是两个方法:querySelector()和querySelectorAll().在兼容的浏览器中,可以通过Document及Element类型的实例调用它们.目前完全支持Selector API Level 1的浏览器有IE 8+. Firefox 3.5+. Safari 3.1+. Chrome和Opera 10+. querySelector()方法接收一个CSS选择符,返回与该模式匹配的第一个元素,

JavaScript高级程序设计-读书笔记(3)

第8章 BOM 1.window对象 (1)全局作用域 BOM的核心对象是window,它表示浏览器的一个实例.在浏览器中,window对象既是通过JavaScript访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象. 所有在全局作用域中声明的变量.函数都会变成window对象的属性和方法. (2)窗口关系及框架 如果界面中包含框架,这每个框架都拥有自己的window对象,并且保存在frames集合中,可以通过数值的索引(从0开始,从左至右,从上到下)或者框架名称来访问相

JavaScript 高级程序设计读书笔记(1)

第6章 面向对象的程序设计 属性的类型 JS 中对象的属性有两种,数据属性和访问器属性(accessor property ),属性有其自身的特性(arrribute),可以理解为关于属性的属性. 数据属性包含4个特性,分别是[[Configurable]], [[Enumerable]], [[Writable]], [[Value]]. 使用 Object.defineProperty 修改属性描述符时,若该属性之前不存在,除了代码里指定的特性值,其他特性值默认将是 false, 举例如下:

javascript高级程序设计 读书笔记1

第二章  在HTML中使用JS 加载JS有三种:行内,head头部和外部链接JS   最好使用外部链接<script src="example.js" ></script>(推荐),在script标签中不需要放任何代码,放了也会被忽略.也可以使用<script src="example.js" /> 但是语法不符合HTML规范  所以不要这样写. 在传统做法中,script放在head中,但是会等到加载完JS再执行DOM,页面会延