第五章:引用类型

Object类型

创建object实例的两种方式:

1.new方式

var person = new Object();

person.name = “haozk”;

person.age = 24;

2.对象字面量表示法

var person = {

name:”haozk”,

age:24

}

也能够将属性用字符串包围:

var person = {

“name”:”haozk”,

“age”:24

}

訪问object实例的属性,也有两种方式:

1.alert(person[“name”])   //方括号方式(能够通过变量来訪问属性,属性也能够为keyword或者保留字)

2.alert(person.name)     //点方式

Array类型

不同于其它编程语言的array。js中的array具有stringbuffer的动态调整大小。又数据项类型能够不同样。

创建也有两种方式,new与数组字面量方式:

var colors = new Array();

var colors = new Array(3);

var colors = new Array(“red”,”blue”,”green”);

var colors = [];

var colors = [“red”,”blue”,”green”];

数组的length属性不是仅仅读的,能够改变:

colors.length = 2;

alert(colors[2]);     //undefined

colors[colors.length] = ‘black’;  //在位置2,加入一种颜色,如今的length为3.

检測数组:(重要)

Array.isArray()方法

if(Array.isArray(value)){

//对数组的相关操作

}

转换方法:

调用数组的toLocaleString()、toString()、valueOf(),返回结果都是每项以逗号分隔的字符串。

alert()接受字符串參数。会在后台调用toString()方法,所以能够直接alert(colors).

调用join()方法,能够接受參数,作为分隔的字符串。如:

alert(colors.join[“||”])   //red||blue||green

栈方法:push(),pop()

队列方法:push(),shift(),unshift(能在数组前端加入随意个项并返回新数组的长度)

重排序方法:

反转:reverse()

升序:sort() (注意:是按字符串排序而不是数值)

function compare(value1,value2){ //升序   (通用)

if(value1<value2){

return -1;  //若降序,return 1;

}else if(value1>value){

return 1;  //若降序。return -1;

}else{

return 0;

}

}

var values = [0,1,5,10,15];

values.sort(compare);

alert(values);

操作方法:contact(),slice(),splice()

位置方法:indexOf(),lastIndexOf()

迭代方法:every(),filter(),forEach(),map(),some()

缩小方法:reduce(),reduceRight()

《javascript高级程序设计》读书笔记(四)引用类型的更多相关文章

  1. javascript高级程序设计读书笔记-事件(一)

    读书笔记,写的很乱   事件处理程序   事件处理程序分为三种: 1.html事件2. DOM0级,3,DOM2级别  没有DOM1 同样的事件 DOM0会顶掉html事件   因为他们都是属性  而 ...

  2. javascript高级程序设计读书笔记----引用类型

        Array类型. ECMAScript数组的每一项可以保存任何类型的数据. 数组大小是可以动态调整的. 创建数组第一种基本方式方式: 使用Array构造函数 var colors = new ...

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

    第6章  面向对象的程序设计 6.2 创建对象 创建某个类的实例,必须使用new操作符调用构造函数会经历以下四个步骤: 创建一个新对象: 将构造函数的作用域赋给新对象: 执行构造函数中的代码: 返回新 ...

  4. JavaScript高级程序设计 读书笔记

    第一章 JavaScript 简介 第二章 Html中使用JavaScript 第三章 基本概念 第四章 变量,作用域,内存 第五章 引用类型 第六章 面向对象 第七章 函数表达式 第八章 BOM 第 ...

  5. javascript高级程序设计读书笔记

    第2章  在html中使用javascript 一般都会把js引用文件放在</body>前面,而不是放在<head>里, 目的是最后读取js文件以提高网页载入速度. 引用js文 ...

  6. 《JavaScript高级程序设计》笔记:引用类型(五)

    Object类型 创建object实例方法有两种.第一种方法使用new操作符后跟object构造函数.如下: var person=new Object(); person.name="Ni ...

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

    第二章  在HTML中使用JS 加载JS有三种:行内,head头部和外部链接JS   最好使用外部链接<script src="example.js" ></sc ...

  8. JavaScript高级程序设计-读书笔记(7)

    第22章 高级技巧 1.高级函数 (1)安全的类型检测 在任何值上调用Object原生的toString()方法,都会返回一个[object NativeConstructorName]格式的字符串. ...

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

    第6章 面向对象的程序设计 创建对象 1.最简单方式创建Object的实例,如 var person = new Object(); person.name = “Greg”; person.age ...

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

    第1章 JavaScript简介 JavaScript是一种专为与网页交互而设计的脚本语言,由下列三个不同的部分组成: l        ECMAScript:提供核心语言功能: l        文 ...

随机推荐

  1. python 实用命令

    列表理解: list = [-1, -2, 1, 2] [item for item in list if item > 0] [1, 2] d = {'person': 2, 'cat': 4 ...

  2. [前端随笔][CSS] 制作一个加载动画 即帖即用

    说在前面 描述 [加载中loading...] 的动画图片往往使用GIF来实现,但GIF消耗资源较大,所以使用CSS直接制作更优. 效果传送门1 效果传送门2 关键代码 @keyframes 规则 用 ...

  3. elasticsearch更新license

    Elasticsearch更新license: 初次安装Marvel,有30天的使用时间,当到期后,只保存7天的数据,所以需要注册申请一个license: 注册申请地址: https://regist ...

  4. electron-builder中NSIS相关配置

    electron-builder中NSIS相关配置 相比较于electron-packager打包,使用electron-builder打包使得包体积更小.在electron-builder中,对于N ...

  5. Bootstrap新版里的a标签点击后出现下划线解决办法

    其实我从失去焦点后发现了下划线消失了就应该知道 Bootstrap对a标签进行了 focus焦点事件. 所以解决办法就是一句:a:focus{text-decoration: none}. 一个笑笑的 ...

  6. CentOS 7 上搭建 ownCloud 私有云

    所需软件 & 环境 操作系统:CentOS 7.3.1711 最小安装 (已关闭 SELinux 和防火墙) 应用软件: Nginx  .MariaDB  .PHP  .ownCloud 10 ...

  7. 如何开启apache的PHP-FPM实例

    PHP-FPM 作为 FastCGI 进程管理器而广为熟知,它是PHPFastCGI 实现的改进,带有更为有用的功能,用于处理高负载的服务器和网站.下面列出其中一些功能: 新功能 拥有具有优雅(gra ...

  8. cordova热更新插件的使用

    cordova常用命令  一.添加插件 新建Cordova项目 cordova create CordovaHotCode com.ezample.hotcode 添加Android平台 在新建项目的 ...

  9. CodeForces 723E One-Way Reform

    构造. 有一种十分巧妙的方法可以使图中所有度数为偶数的节点,经过每条边定向后,出度和入度都相等. 首先统计每个节点的度数,将度数为奇数的节点与编号为$n+1$的节点连边,这样一来,这张新图变成了每个节 ...

  10. What is Double Spending & How Does Bitcoin Handle It?

    https://coinsutra.com/bitcoin-double-spending/ Bitcoin is gaining rapid popularity and adoption acro ...