JavaScript | 关于内置对象

276 阅读2分钟

目标

  • 能够说出什么是内置对象
  • 能够根据文档查询指定API的使用方法
  • 能够使用Math对象的常用方法
  • 能够使用Date对象的常用方法
  • 能够使用Array对象的常用方法
  • 能够使用String对象的常用方法

目录

  • 内置对象
  • 查文档
  • Math对象
  • 日期对象
  • 数组对象
  • 字符串对象

1. 内置对象

  • JavaScript中的对象分为3种:自定义对象、内置对象、浏览器对象
  • 前面两种对象是JS基础内容,属于ECMAScript;第三个浏览器对象属于我们JS独有的,我们JS API讲解
  • 内置对象就是指JS语言自带的一些对象,这些对象供开发者使用,并提供了一些常用的或是最基本而必要的功能(属性和方法)
  • JavaScript提供了多个内置对象:Math、 Date . Array、string等

2. 查文档

2.1 MDN

学习一个内置对象的使用,只要学会其常用成员的使用即可,我们可以通过查文档学习,可以通过MDN/W3C来查询。

Mozilla开发者网络(MDN)提供了有关开放网络技术(Open Web )的信息,包括HTML、CSS和万维网及HTML5应用的API。

MDN网址

2.2 如何学习对象中的方法

  1. 查阅该方法的功能
  2. 查看里面参数的意义和类型
  3. 查看返回值的意义和类型
  4. 通过demo进行测试

3. Math数学对象

最大值,PI之类的

         console.log(Math.PI)
         console.log(Math.max(1,2));

封装自己的数学对象

利用对象封装自己的数学对象里面有PI最大值和最小值

        var myMath = {
            PI: 3.14159,
            max: function() {
                var max = arguments[0];
                for(var i =1 ; i< arguments.length; i++){
                    if(arguments[i] > max) {
                        max = arguments[i];
                    }
                }
                return max
            },
            min:function() {
                var min = arguments[0];
                for(var i =1 ; i< arguments.length; i++){
                    if(arguments[i] < min) {
                        min = arguments[i];
                    }
                }
                return min
            }

        }

        console.log(myMath.max(1,5,9));

数学的东西就用math吧

3.1 常用的math方法

  • abs 绝对值
  • floor 向下取整
  • ceil 向上取整
  • round 四舍五入取整

  • random() 随机小数

4. date日期对象

4.1 date概述

  • Date对象和Math对象不一样,他是一个构造函数,所以我们需要实例化后才能使用

会打印出当前时间

4.2 date方法的使用

        var date = new Date();
        console.log(date);

  • 如果括号里面有时间,就返回参数里面的时间。
var date1 = +new Date(); 
//+new Date()返回的就是总的毫秒数
console.log(date1);

// H5新增的获得总的毫秒数
console.log(Date.now());

4.3 倒计时做法(重要)

  1. 核心算法:输入的时间减去现在的时间就是剩余的时间,即倒计时,但是不能拿着时分秒相减,比如05分减去25分,结果会是负数的。
  2. 用时间戳来做。用户输入时间总的毫秒数减去现在时间的总的毫秒数,得到的就是剩余时间的毫秒数。
  3. 把剩余时间总的亳秒数转换为天、时、分、秒(时间戳转换为时分秒)

转换公式如下:

  • d = parselnt(总秒数/60/60/24);计算天数
  • h = parseInt(总秒数/60/60%24)计算小时
  • m = parselnt(总秒数/60 %60);计算分数
  • s = parselnt(总秒数%60);计算当前秒数
        function countDown(time) {
            var nowTime = +new Date();//返回当前时间总毫秒数
            var inputTime = +new Date(time); //返回用户输入的总毫秒数
            var times = (inputTime - nowTime) / 1000; //times是剩余事件秒数

            var d = parseInt(times / 60 / 60 / 24);//天
            d = d  < 10 ? '0'+d : d;
            var h = parseInt(times / 60 / 60 % 24)//时
            h = h < 10 ? '0'+h : h;
            var m = parseInt(times / 60 % 60);// 分
            m = m < 10 ? '0'+m : m;
            var s = parseInt(times % 60); //秒
            s  =   s < 10 ? '0'+s : s;

            return d + '天' + h + '时' + m + '分' + s + '秒'

        }
        
        console.log(countDown('2021-6-22 18:00:00'));

5. 数组对象

5.1 创建数组对象的两种方式

  • 字面量方式
  • new Array()

5.2检测是否为数组

  • instanceof 运算符
  • Array.isArray(参数);[更好,ie9才支持]

5.3 添加删除数组元素的方法

方法名说明返回值
push(参数1....)末尾添加一个或多个元素,注意修改原数组并返回新的长度
pop()删除数组最后一个元素,把数组长度减1无参数、修改原数组返回它删除的元素的值
unshift(参数1...)向数组的开头添加一个或更多元素,注意修改原数组并返回新的长度
shift()删除数组的第一个元素,数组长度减1无参数.修改原数组并返回第一个元素的值

5.4 数组排序

方法名说明是否修改原数组
reverse()颠倒数组中元素的顺序,无参数该方法会改变原来的数组返回新数组
sort()对数组的元素进行排序该方法会改变原来的数组返回新数组

固定排序写法

arr.sort(function(a,b){
    return a-b;
}) 

5.5 数组索引方法

方法名说明返回值
indexOf数组中查找给定元素的第一个索引如果存在返回索引号如果不存在,则返回-1。
lastindexOf()在数组中的最后一个的索引如果存在返回索引号如果不存在,则返回-1.

5.6 数组去重(重点案例)

有一个数组[ 'c','a', 'z', 'a', 'x', 'a', 'x', 'c','b'],要求去除数组中重复的元素。

方法:把旧数组里面不重复的元素选取出来放到新数组中,重复的元素只保留一个,放到新数组中去重。

核心算法:我们遍历旧数组,然后拿着旧数组元素去查询新数组,如果该元素在新数组里面没有出现过,我们就添加,否则不添加。 我们怎么知道该元素没有存在?利用新数组.indexOf(数组元素)如果返回时–1就说明新数组里面没有改元素

        function unique(arr) {
            var newArr = [];
            for (i = 0; i < arr.length; i++){
                if(newArr.indexOf(arr[i]) === -1) {
                    newArr.push(arr[i]);
                }
            }
            return newArr;
        }

        var demo = unique(['c','a', 'z', 'a', 'x', 'a', 'x', 'c','b'])
        console.log(demo);

5.6 数组转换为字符串

方法名说明
toString()把数组转换成字符串,逗号分隔每一项
join('分隔符')方法用于把数组中的所有元素转换为一个字符串。

6. 字符串对象

6.1 基本包装类型

为了方便操作基本数据类型,JavaScript还提供了三个特殊的引用类型:String、Number和Boolean.

基本包装类型就是把简单数据类型包装成为复杂数据类型,这样基本数据类型就有了属性和方法。

假设 var str = 'nizhenshuai'

相当于

var temp = new string('nizhenshuai');//生成临时变量,把简单包装成复杂的

str = temp // 复制给我们声明的变量

temp = null 销毁临时变量

6.2 字符串的不可变

指的是里面的值不可变,虽然看上去可以改变内容,但其实是地址变了,内存中新开辟了一个内存空间。

所以不要大量拼接字符串

操作完成后都会生成个新的

6.3 根据字符返回下标

  • indexof

6.4 经典题

查找字符串"abcoefoxyozopp"中所有o出现的位置以及次数

算法:

  1. 查找第一个o的位置
  2. 只要indexof返回的结果不是-1 就继续找
  3. 因为indexOf只能查找到第一个,所以后面的查找,利用第二个参数,当前索引加1,从而继续查找
        var str = "abcoefoxyozzopp" ;
        var index = str.indexOf('o');
        var num = 0;
        while (index !==-1) {
            console.log(index);
            num++;
            index = str.indexOf('o',index + 1);
        }
        console.log('O出现的次数' + num);

6.5 根据位置返回字符(重点)

方法名说明使用
charAt(index)返回指定位置的字符(index字符串的索引号)str.charAt(O)
charCodeAt(index)获取指定位置处字符的ASCII码(index索引号)str.charCodeAt(0)
str[index]获取指定位置处字符HTML5,IE8+支持和charAt()等效

6.6 小案例

判断一个字符串'abcoefoxyozzopp'中出现次数最多的字符,并统计其次数。

  • 核心:用charAt()遍历字符串
  • 把每个字符都存储给对象,如果对象没有该属性,就为1,如果存在了就+1
  • 遍历对象,得到最大值和该字符
        var str = 'yuehanshizhendeshuai';
        var o = {};
        //遍历所有字符
        for(var i = 0 ; i< str.length;i++) {
            var chars = str.charAt(i);
            if(o[chars]){
                o[chars]++;
            }else {
                o[chars] = 1;
            }
        }
        // 遍历对象
        var max =0 ; 
        var ch = '';
        for (var k in o) {
            //k是属性名
            //o[k]是值
            if (o[k] > max) {
                max = o[k];
                ch = k;
            }

        }
        console.log(max);
        console.log('最多的字符是' + ch+','+'次数为'+max);

6.7 字符串操作方法(重点)

方法名说明
concat(str1,str2,str3...)concat()方法用于连接两个或多个字符串。拼接字符串,等效于+,+更常用
substr(start,length)从start位置开始(索引号), length取的个数重点记住这个
slice(start, end)从start位置开始,截取到end位置,end取不到(他们俩都是索引号)
substring(start, end)从start位置开始,截取到end位置,end取不到基本和slice相同但是不接受负值

replace 替换字符

split(‘分隔符’) 字符串转换为数组