js内置函数

Javascript考点

内置对象

Math

Math.<方法名>(参数);

Math.abs(x) --- 绝对

功能:返回数字 x 的绝对值。
语法:Math.abs(x)

console.log(Math.abs(-5)); // 输出 5
console.log(Math.abs(10)); // 输出 10

Math.ceil(x) --- 天花板

功能:返回大于或等于 x 的最小整数(向上取整)。
语法:Math.ceil(x)

console.log(Math.ceil(4.2)); // 输出 5
console.log(Math.ceil(-4.2)); // 输出 -4

Math.floor(x) --- 地板

功能:返回小于或等于 x 的最大整数(向下取整)。
语法:Math.floor(x)

console.log(Math.floor(4.7)); // 输出 4
console.log(Math.floor(-4.7)); // 输出 -5

Math.round(x) --- 大概

功能:返回四舍五入后的整数。
语法:Math.round(x)

console.log(Math.round(4.5)); // 输出 5
console.log(Math.round(4.4)); // 输出 4

Math.max(x, y, ...) ---max

功能:返回一组数中的最大值。
语法:Math.max(a, b, c, ...)

console.log(Math.max(1, 2, 3, 4)); // 输出 4
console.log(Math.max(-1, -2, -3)); // 输出 -1

Math.min(x, y, ...) ---min

功能:返回一组数中的最小值。
语法:Math.min(a, b, c, ...)

console.log(Math.min(1, 2, 3, 4)); // 输出 1
console.log(Math.min(-1, -2, -3)); // 输出 -3

Math.random() ---random

功能:返回一个 0到1 之间的随机浮动数(包括 0,但不包括 1)。
语法:Math.random()

console.log(Math.random()); // 输出一个随机数,例如 0.7623

Math.pow(x, y) ---pow

功能:返回 x 的 y 次幂,即 x^y。
语法:Math.pow(x, y)

console.log(Math.pow(2, 3)); // 输出 8,因为 2^3 = 8
console.log(Math.pow(3, 2)); // 输出 9,因为 3^2 = 9

Math.sqrt(x)

功能:返回 x 的平方根。
语法:Math.sqrt(x)

console.log(Math.sqrt(9)); // 输出 3,因为 9 的平方根是 3
console.log(Math.sqrt(16)); // 输出 4,因为 16 的平方根是 4

Math.sin(x)、Math.cos(x)、Math.tan(x)

功能:分别返回 x 的正弦、余弦和正切值。参数 x 必须是弧度制。
语法:
Math.sin(x)
Math.cos(x)
Math.tan(x)

console.log(Math.sin(Math.PI / 2)); // 输出 1,π/2 的正弦值是 1    //PI是Π
console.log(Math.cos(Math.PI)); // 输出 -1,π 的余弦值是 -1
console.log(Math.tan(Math.PI / 4)); // 输出 1,π/4 的正切值是 1

Math.log(x)

功能:返回 x 的自然对数(以 e 为底)。
语法:Math.log(x)

console.log(Math.log(10)); // 输出 2.302585092994046,因为 ln(10) ≈ 2.302

Math.exp(x) ---e的X pow

功能:返回 e 的 x 次幂(自然对数的底 e,约为 2.718)。
语法:Math.exp(x)

console.log(Math.exp(1)); // 输出 2.718281828459045,因为 e^1 ≈ 2.718

常用的 Math 常量

(1)Math.PI
功能:表示圆周率 π(大约 3.14159)。
语法:Math.PI
console.log(Math.PI); // 输出 3.141592653589793

(2) Math.E
功能:表示自然对数的底数 e(大约 2.718)。
语法:Math.E
console.log(Math.E); // 输出 2.718281828459045

(3) Math.LN2
功能:表示 2 的自然对数(大约 0.693)。
语法:Math.LN2
console.log(Math.LN2); // 输出 0.6931471805599453

(4) Math.LN10
功能:表示 10 的自然对数(大约 2.302)。
语法:Math.LN10
console.log(Math.LN10); // 输出 2.302585092994046

(5) Math.SQRT2
功能:表示 2 的平方根(大约 1.414)。
语法:Math.SQRT2
console.log(Math.SQRT2); // 输出 1.4142135623730951

(6) Math.SQRT1_2
功能:表示 1/2 的平方根(大约 0.707)。
语法:Math.SQRT1_2
console.log(Math.SQRT1_2); // 输出 0.7071067811865476

(7) Math.LOG2E
功能:表示 e 的对数,以 2 为底(大约 1.442)。
语法:Math.LOG2E
console.log(Math.LOG2E); // 输出 1.4426950408889634

Date

在 JavaScript 中,Date 对象用于处理和操作日期和时间。它是一个非常强大的工具,能够帮助你获取当前时间、格式化日期、比较日期等。

创建 Date 对象

(1) 创建当前日期和时间
const now = new Date();
console.log(now); // 输出当前的日期和时间,Sun Nov 10 2024 20:54:08 GMT+0800 (中国标准时间)
这种方式不传参数,返回当前的日期和时间。

(2) 创建指定日期和时间
1.使用日期字符串:
const date1 = new Date("2024-11-10");
console.log(date1); // 输出 2024-11-10T00:00:00.000Z

2.使用年月日(不带时间):--->数组下标规则
const date2 = new Date(2024, 10, 10); // 注意:月份从 0 开始,10 表示 11 月
console.log(date2); // 输出 2024-11-10T00:00:00.000Z

3.使用年月日时分秒:
const date3 = new Date(2024, 10, 10, 12, 30, 0);
console.log(date3); // 输出 2024-11-10T12:30:00.000Z

4.使用时间戳:
!!!有点懵
const date4 = new Date(1699680000000); // 时间戳单位为毫秒
console.log(date4); // 输出对应的日期,例如 2024-11-10T00:00:00.000Z

获取和设置日期和时间的各个部分

获取年、月、日、小时、分钟、秒等

getFullYear():获取四位年份(例如 2024)。
getMonth():获取月份(0-11,0 代表 1 月,11 代表 12 月)。
getDate():获取日期(1-31 !!!!)。
getDay():获取星期几(0-6,0 代表星期日,6 代表星期六)。
getHours():获取小时(0-23)。
getMinutes():获取分钟(0-59)。
getSeconds():获取秒(0-59)。
getMilliseconds():获取毫秒(0-999)。

const date = new Date("2024-11-10T12:30:00");
console.log(date.getFullYear());   // 输出 2024
console.log(date.getMonth());      // 输出 10 (表示 11 月)
console.log(date.getDate());       // 输出 10
console.log(date.getDay());        // 输出 0 (星期日)
console.log(date.getHours());      // 输出 12
console.log(date.getMinutes());    // 输出 30
console.log(date.getSeconds());    // 输出 0
console.log(date.getMilliseconds());// 输出 0
设置年、月、日、小时、分钟、秒等

setFullYear(year):设置年份。
setMonth(month):设置月份(0-11)。
setDate(date):设置日期(1-31)。
setHours(hour):设置小时(0-23)。
setMinutes(minute):设置分钟(0-59)。
setSeconds(second):设置秒(0-59)。
setMilliseconds(milliseconds):设置毫秒(0-999)。

const date = new Date();
date.setFullYear(2025);
date.setMonth(0);  // 设置为 1 月
date.setDate(15);   // 设置日期为 15
console.log(date);  // 输出类似 2025-01-15T... 的日期
日期的比较[时间戳比较]

你可以通过比较两个 Date 对象来判断它们的先后关系
比较时间戳:使用 getTime() 方法获取时间戳,然后直接进行比较。

const date1 = new Date("2024-11-10");
const date2 = new Date("2025-11-10");
if (date1.getTime() < date2.getTime()) {
  console.log("date1 is earlier than date2");
} else {
  console.log("date1 is later than or the same as date2");
}

日期格式化 --掌握一两个就好

JavaScript 中的 Date对象本身没有内建的格式化方法(即没有像 toString("yyyy-MM-dd") 这样的功能),但你可以使用一些方法将日期转为字符串

toDateString()

将日期转换为易读的格式(去掉时间部分)。

const date = new Date("2024-11-10T12:30:00");
console.log(date.toDateString()); // Sun Nov 10 2024
toTimeString() --->好棒!!

将时间转换为易读的时间格式。

const date = new Date("2024-11-10T12:30:00");
console.log(date.toTimeString()); // 12:30:00 GMT+0800 (中国标准时间)
toISOString()

返回 ISO 格式的字符串,通常用于API 传输。

const date = new Date("2024-11-10T12:30:00");
console.log(date.toISOString()); // 2024-11-10T04:30:00.000Z
toLocaleString() --好棒!!

返回本地化的日期和时间字符串,格式根据浏览器的语言环境而有所不同。

const date = new Date("2024-11-10T12:30:00");
console.log(date.toLocaleString()); // 2024/11/10 12:30:00

日期的加减

JavaScript Date 对象没有直接支持加减日期的方法,但你可以通过设置日期的各个部分来手动实现。

增加天数
const date = new Date("2024-11-10");
date.setDate(date.getDate() + 5); // 增加 5 天
console.log(date);  // Fri Nov 15 2024 08:00:00 GMT+0800 (中国标准时间)
console.log(date.toLocaleString());  //2024/11/15 08:00:00

减少天数
const date = new Date("2024-11-10");
date.setDate(date.getDate() - 5); // 减少 5 天
console.log(date);  // 输出 2024-11-05
增加月份

const date = new Date("2024-11-10");
date.setMonth(date.getMonth() + 2); // 增加 2 个月
console.log(date);  // 输出 2025-01-10
增加年份
const date = new Date("2024-11-10");
date.setFullYear(date.getFullYear() + 1); // 增加 1 年
console.log(date);  // 输出 2025-11-10

日期和时间戳

  1. 你可以通过 getTime() 方法获取一个 Date 对象的时间戳
const date = new Date();
console.log(date.getTime());  // 输出当前时间的时间戳,例如 1678502399973
  1. 你还可以通过 Date.now() 获取当前的时间戳:
console.log(Date.now());  // 输出当前时间的时间戳

总结
Date 对象是 JavaScript 中非常重要的一个工具,能够帮助你处理日期和时间。
通过它,你可以:
获取和设置日期、时间的各个部分(如年、月、日、时、分、秒等)。
比较不同日期之间的大小。
格式化日期为字符串。
计算日期的加减。
获取和转换为时间戳。

Array

        //1.find()
        const arry1 = [5,12,8,130,44];
        const found = arry1.find(a => a > 10);
        // 这一行使用了find方法,它是JavaScript数组对象的一个方法,用于找出第一个满足提供的测试函数的元素。
        // find()的箭头函数:变量名 => 条件【满足条件返回它所找到的第一个值,不满足返回undefined】
        console.log(found);//[12]

        //2.filter()
        const arry1 = [5, 12, 8, 130, 44];
        const filtered = arry1.filter(element => element > 10); // 返回所有大于10的元素组成的新数组
        console.log(typeof filtered); // object--->数组是特殊的对象
        console.log(filtered); // [12,130,44]
        console.log(Array.isArray(filtered)); //  true
        // 返回一个新数组,包含所有满足条件的元素,没有就返回空数组。

        // 3.include() 
        const array = [1, 2, 3, 4, 5];
        if (array.includes(3&&4)) { // 检查数组是否包含元素3
        console.log('数组包含元素 3和4');
        } else {
        console.log('数组不包含元素 3或4');
        }
        // 检查数组里有没有相应的值

        //4.Array.isArray()
        console.log(Array.isArray(变量)); // true
        //检查是不是Array类型

        //5.push()
        const arr = [1, 2, 3]
        arr.push(8)
        console.log(arr) // [1, 2, 3, 8]
        //在数组后面添加数字

        //6.pop()
        const arr = [1, 2, 3]
        const popVal = arr.pop()//移除arr里最后一个元素,并返回它给popVal
        console.log(popVal) // 3 -->被移走的元素
        console.log(arr) // [1, 2]

        //栈 -->

        // ① 数组模拟常见数据结构之一:栈
        const stack = [0, 1]
        stack.push(2) // 压栈
        console.log(stack) // [0, 1, 2]
        
        const popValue = stack.pop() // 出栈
        console.log(popValue) // 2
        console.log(stack) // [0, 1]

        //7.unshift()
        const arr = [1, 2, 3]
        arr.unshift(0)
        console.log(arr) // [0, 1, 2, 3]

        //8.shift()
        const arr = [1, 2, 3]
        const shiftVal = arr.shift()--移除arr里第一一个元素,并返回它给shiftVal
        console.log(shiftVal) // 1  -->被移走的元素 
        console.log(arr) // [2, 3] 

        // ②数组模拟常见数据结构之一:队列
        const queue = [0, 1]
        queue.push(2) // 入队
        console.log(queue) // [0, 1, 2]     
        const shiftValue = queue.shift() // 出队
        console.log(shiftValue) // 0
        console.log(queue) // [1, 2]

        //9.concat()
        const arr = [1, 2, 3]
        const arr2 = arr.concat([7, 8, 9])
        console.log(arr) // [1, 2, 3]
        console.log(arr2) // [1, 2, 3, 7, 8, 9]
        //把concat括号里的内容放到原数组的后面

        //10.ndexof()
        const arr = [1, 2, 3]
        console.log(arr.indexOf(2)) // 1
        console.log(arr.indexOf(-1)) // -1
        // 在数组中寻找该值,找到则返回其下标,找不到则返回-1。

        //11.join()
        const arr = [1, 2, 3]
        console.log(arr.join()) // ‘1, 2, 3’//将数组转化成字符串,并返回该字符串,不传值则默认逗号隔开,
        console.log(arr) // [1, 2, 3]//原数组不变。
        // 将数组转化成字符串,并返回该字符串,不传值则默认逗号隔开,原数组不变。
        let fruits = ["Apple", "Banana", "Cherry"];
        let result = fruits.join(", "); // 使用逗号和空格作为分隔符

        //12.reverse()
        console.log(result); // 输出: Apple, Banana, Cherry
        const arr = [1, 2, 3]
        console.log(arr.reverse()) // [3, 2, 1]
        console.log(arr) // [3, 2, 1]
        // 翻转原数组,并返回已完成翻转的数组,原数组改变。

        13. slice(start,end)
        const arr = [1, 2, 3, 4, 5]
        console.log(arr.slice(1, 4)) // [2, 3, 4]
        //角标为1 --- 角标为3
        console.log(arr) // [1, 2, 3, 4, 5]
        // 从start 开始截取到end,但是不包括end

        //14.splice(index1,index2,new1,new2,new3.....)
        const arr3 = [1, 2, 3, 4, 5, 6, 7, "f1", "f2"];
        const arr4 = arr3.splice(2, 3) 
        console.log(arr4); // [3, 4, 5];
        console.log(arr3); // [1, 2, 6, 7, "f1", "f2"];    
        const arr5 = arr3.splice(2, 0, "wu", "leon"); //插入的元素在选定下标位置前面
        console.log(arr5); // [] 返回空数组
        console.log(arr3); // [1, 2, "wu", "leon", 6, 7, "f1", "f2"];    
        const arr6 = arr3.splice(2, 3, "xiao", "long");
        console.log(arr6); // ["wu", "leon", 6]
        console.log(arr3); //[ 1, 2, "xiao", "long", 7, "f1", "f2"]        
        const arr7 = arr3.splice(2); 
        console.log(arr7);// ["xiao", "long", 7, "f1", "f2"]
        console.log(arr3); // [1, 2]
        原数组删除从下标index1开始num个元素【包括端点】,如果需要被删元素,将它存到新的变量里就好
        p.s.如果num不写,默认删光下标开始所有元素

        //15.sort((a, b) => a - b)--从小到大
        //15.sort((a, b) => b - a)--从大到小
        const arr = [1, 4, 3]
        arr.sort((a, b) => b - a)
        console.log(arr) // [4, 3, 1]
        const arrplus = [1, 4, 3]
        arrplus.sort((a, b) => a - b)
        console.log(arrplus) // [1, 3, 4]

        //16.tostring()
        const arr = [1, 2, 3, 4, 5]
        console.log(arr.toString()) // ‘1, 2, 3, 4, 5’
        console.log(arr) // [1, 2, 3, 4, 5]
        将数组变成字符串 将数组转化成字符串,并返回该字符串,**逗号**隔开,原数组不变。

String

        //1.charAt
        var father = 'abcdefg'
        let son = father.charAt(2)
        console.log(son) // 输出 'c' 
        console.log(father[3]) // 输出 'd'
        // 返回指定索引位置处的字符。类似于数组用中括号获取相应下标位置的数据。

        //2.concat()
        const str1 = 'abcdefg'
        const str2 = '1234567'
        const str3 = str1.concat(str2)
        console.log(str3) // 输出 'abcdefg1234567'
        // 类似数组的concat(),用来返回一个合并拼接两个或两个以上字符串。原字符串不变。

        //3.indexOf()  lastIndexOf()
        const str = 'abcdcefcg'
        console.log(str.indexOf('c')) //  '2'
        console.log(str.lastIndexOf('c')) //  '7'
        // indexOf,返回一个字符在字符串中首次出现的位置,
        // lastIndexOf返回一个字符在字符串中最后一次出现的位置。

        //4.slice(index,endIndex)  --->endl:截至位置下标
        const str = 'abcdefg'
        console.log(str.slice()) // 'abcdefg'
        console.log(str.slice(1)) // 'bcdefg'
        console.log(str.slice(2, str.length-1)) // 'cdef'

        //5.split()
        const str = 'A*B*C*D*E*F*G'
        console.log(str.split('*')) // ["A", "B", "C", "D", "E", "F", "G"]     
        const str1 = 'ABC*DEF*G'
        console.log(str1.split('*')) //  ['ABC', 'DEF', 'G']
        // 使用指定的分隔符将一个字符串拆分为多个子字符串数组并返回,原字符串不变。

        //6.substr(index)-->从index开始,后面都砍掉
        //6.substr(index, length)-->从index开始,长度为length删掉
        const str = 'ABCDEFGHIJKLMN'
        console.log(str.substr(2))  // 'CDEFGHIJKLMN'
        console.log(str.substr(2, 9))  //'CDEFGHIJK'
        // substr的参数二如果为0或者负数,则返回一个空字符串,如果未填入,则会截取到字符串的结尾去。substring的参数一和参数二为NAN或者负数,那么它将被替换为0。

        //7.substring(index,newIndex)-->从index开始,newIndex截至【不包括newIndex】
        //7.substring(index)-->从index开始,后面都砍掉
        const str = 'ABCDEFGHIJKLMN'
        console.log(str.substring(2)) //'CDEFGHIJKLMN' 
        console.log(str.substring(2, 9))  //'CDEFGHI'
         
        //8.match()
        const str = '2018年结束了,2019年开始了'
        const reg = /\d+/g  // 这里是定义匹配规则,匹配字符串里的1到多个数字
        // /\d+/g 是一个全局正则表达式,\d 匹配任何数字(等价于 [0-9]),+ 表示匹配一次或多次。g 标志代表全局匹配    
        console.log(str.match(reg))  // 输出符合匹配规则的内容,以数组形式返回 ['2018', '2019']
        console.log(str.match('年'))  // 不使用正则 ["20", index: 4, input: "2018年结束了,2019年开始了"]
        console.log(str.match('20'))  // 不使用正则 ["20", index: 0, input: "2018年结束了,2019年开始了"]
        // 当你传递一个字符串(而不是正则表达式)给 match() 方法时,它会返回第一个与该字符串匹配的子串的信息。返回值是一个数组,其中第一个元素是匹配的子串,index 属性是匹配子串在原字符串中的位置,input 属性是原字符串本身。

        //9.search(number)
        const str = '2018年结束了,2019年开始了,2020年就也不远了'
        const reg = /\d+/i  // 这里是定义匹配规则,匹配字符串里的1到多个数字
        console.log(str.search(reg)) // 输出 0  这里搜索到的第一项是从位置0开始的

        //10.toLowerCase(变量名) -->全转小写
        //10.toUpperCase(变量名) -->全转大写
        const str1 = 'A!cd1fg'
        const str2 = 'aBCDEFG'
        console.log(str2.toLowerCase())  // 'abcdefg'
        console.log(str1.toUpperCase())  // 'A!CD1FG'
        // 数字,特殊符号不变

        // 11.includes('X')
        // 11.startsWith('X')
        // 11.endsWith('X')
        const str = 'Excuse me, how do I get to park road?'
        console.log(str.includes('how')) // true
        console.log(str.startsWith('Excuse')) //  true
        console.log(str.endsWith('?')) // true
        //包含X?  以X为开头?  以X为结尾?

        //12.repear(times)
        const str = 'http'
        const str2 = str.repeat(3)
        console.log(str) // 输出:'http'
        console.log(str2) // 输出:'httphttphttp'
        //重复次数


        //13.replace()
        const str = '2018年结束了,2019年开始了,2020年就也不远了'
        const rex = /\d+/g  
        const str1 = str.replace(rex, '****') 
        console.log(str1) // "****年结束了,****年开始了,****年也不远了"
        const str2 = str.replace(rex, function(item){
            console.log(arguments)
            const arr = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖']
            let newStr = ''
            item.split('').map(function(i){
                    newStr += arr[i]
            })					
            return newStr       
        })
        console.log(str2) //贰零壹捌年结束了,贰零壹玖年开始了,贰零贰零年也不远了

posted @ 2024-11-10 21:33  GJ504b  阅读(5)  评论(0编辑  收藏  举报