JavaScript连载20-数据存储方式、内置对象Array详解

一、堆和栈,数据的存储方式

1.注意点:

JS中是没有堆和栈的概念,我们用堆和栈来讲解,目的就是方柏霓讲解,存储方式是一致的。

2.存储方式:

基础数据类型进行值传递,复杂数据类型进行地址传递

 

 

运行结果JavaScript连载20-数据存储方式、内置对象Array详解_第1张图片

二、内置对象

1.Array对象属性

  • 检测一个对象是否是数组

两种方法,内置方法instanceof和一种成员方法isArray(变量)

    //1.检测一个对象是否是数组
    var arr = ["zhansan","lisi","wangwu"];
    console.log(arr instanceof Array);
    console.log(arr instanceof Object);//这句话可以看出数组也是一种对象
    console.log(arr instanceof Function);//数组不是函数类型
    //另一种方法,成员方法     .isArray()
    console.log(Array.isArray(arr));
    console.log(Array.isArray("arr"));

 

 

运行结果JavaScript连载20-数据存储方式、内置对象Array详解_第2张图片

  • 数组常用API

toString()把数组转换成字符串,逗号分隔每一项;valueOf成员方法返回数组本身。

    //2.数组常用API
    var arr = ["zhangsan","lisi"];
    console.log(arr.toString());
    console.log(arr.valueOf());//返回的是数组本身
    //3.join(sperator)方法,将数组的元素组成一个字符串,以seperator为分隔符,省略的话则默认用逗号为
    //分隔符,该方法只接受一个参数:即分隔符。
    console.log(arr.join("-"));
    console.log(arr.join("^"));
    //4.压栈,出栈
    arr.push("附加的");//返回值就是数组的总长度
    console.log(arr.toString());
    arr.pop();
    console.log(arr.toString());
    console.log("=======================");
    //5.shift()函数,是相当于从头部进行删除
    arr.push("sdohf");
    arr.push("nvl");
    console.log(arr.toString());
    arr.shift();
    console.log(arr.toString());

 

 

运行结果JavaScript连载20-数据存储方式、内置对象Array详解_第3张图片

三、源码:

  • D20_1_DataExpressionInMemory.html
  • D20_2_Built-inObject.html \
  • 地址:
    https://github.com/ruigege66/JavaScript/blob/master/D20_1_DataExpressionInMemory.html 
    https://github.com/ruigege66/JavaScript/blob/master/D20_2_Built-inObject.html \
  • 博客园:https://www.cnblogs.com/ruigege0000/
  • 欢迎关注微信公众号:傅里叶变换,个人账号,仅用于技术交流,后台回复“礼包”获取Java大数据学习视频礼包
  • JavaScript连载20-数据存储方式、内置对象Array详解_第4张图片

你可能感兴趣的:(JavaScript连载20-数据存储方式、内置对象Array详解)