百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Js基础31:内置对象(js 内置对象)

wptr33 2025-05-05 19:04 26 浏览

js里面的对象分成三大类:

  1. 内置对象
  2. Array Date Math
  3. 宿主对象
  4. 浏览器提供的对象(如bom、dom等等)
  5. 自定义对象
  6. 开发人员自己定义的对象

内置对象 ——

所谓内置对象,就是JavaScript自带的一些功能对象,里面提供了很多常用、实用的属性和方法,我们需要做的就是学习这些属性和方法怎么使用,在需要用的时候直接用就行

1.1、Math

数学对象 - 用于进行一些和数学相关的运算(计算)的

1、Math.random() 生成一个 [0,1) 之间的随机浮点数

 var r = Math.random();
 console.log(r);// 每次执行等到的数字都一样

2、Math.floor(x) 浮点数进行向下取整

 console.log(Math.floor(3.1));  // 3
 console.log(Math.floor(3.9));  // 3
 console.log(Math.floor(-3.1)); // -4
 console.log(Math.floor(-3.9)); // -4

向下取整就是从这个数字开始,朝数轴的左边找到一个离它最近的整数

3、Math.round(x) 浮点数四舍五入取整

 console.log(Math.floor(3.1));  // 3
 console.log(Math.floor(3.9));  // 4
 console.log(Math.floor(-3.1)); // -3
 console.log(Math.floor(-3.9)); // -4

4、Math.ceil(x) 浮点数进行向上取整

 console.log(Math.floor(3.1));  // 4
 console.log(Math.floor(3.9));  // 4
 console.log(Math.floor(-3.1)); // -3
 console.log(Math.floor(-3.9)); // -3

向上取整就是从这个数字开始,朝数轴的左边找到一个离它最近的整数

5、Math.abs(x) 求一个数的绝对值

 console.log(Math.abs(3));  // 3
 console.log(Math.abs(-3)); // 3

6、Math.max(x,y...) 求多个数字中的最大值

 console.log(Math.max(10,20));  // 20
 console.log(Math.max(8,4,5,7,3)); // 8

这个方法的参数个数是不限定的,想写几个就写几个

7、Math.min(x,y...) 求多个数字中的最小值

 console.log(Math.max(10,20));  // 10
 console.log(Math.max(8,4,5,7,3)); // 3

这个方法的参数个数是不限定的,想写几个就写几个

练习:

求[10,100]之间的随机整数

 Math.floor(Math.random()*(max-min+1)+min)

1.2、Array对象

1、push()从数组最后增加成员

 var aList = [1,2,3,4];
 var res = aList.push(5);
 console.log(res);     //5             返回添加元素后,数组的长度
 console.log(aList);   //[1,2,3,4,5]   原数组。改变

2、pop()从数组最后删除成员

 var aList = [1,2,3,4];
 var res = aList.pop();
 console.log(res);    //4           返回被删除的元素
 console.log(aList);   //[1,2,3]     原数组。改变

3、unshift()从数组前面增加成员

 var aList = [1,2,3,4];
 var res = aList.unshift(5);
 console.log(res);     //5             返回添加元素后,数组的长度
 console.log(aList);   //[5,1,2,3,4]   原数组。改变

4、shift()从数组前面删除成员

 var aList = [1,2,3,4];
 var res = aList.shift();
 console.log(res);    //1           返回删除的元素
 console.log(aList);   //[2,3,4]     原数组。改变

5、reverse() 将数组反转

 var aList = [1,2,3,4];
 var res = aList.reverse();
 console.log(res);    //[4,3,2,1]     返回翻转后的数组
 console.log(aList);   //[4,3,2,1]     原数组。改变

6、splice(index,多少,项1,项2...) : 返回删除的项目删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个项,来替换那些被删除的元素(如果没有,则不替换)

 var aList = [1, 2, 3, 4];
 var res = aList.splice(2, 1,'a','b');
 console.log(res);       //[3]               返回切割掉的元素
 console.log(aList);     //[1,2,'a','b',4]   原数组。改变

以下的方法不会改变原数组

7、slice(start,end): 返回切割项目选取从数组 start位置 到数组的 end位置(不包含end位置) 所有元素,如果没有end,选取从 start 到数组结尾的所有元素

 var aList = [1,2,3,4];
 var res = aList.slice(0,2);
 console.log(res);    //[1,2]           返回切割掉的元素
 console.log(aList);  //[1,2,3,4]       原数组。不变

8、indexOf() 返回数组中元素第一次出现的索引值

 var aList = [3,2,"a",1,2,3,"a"];
 var res = aList.indexOf("a");
 console.log(res);    //2
 
 var res2 = aList.indexOf("a",3);
 console.log(res2)

9、join() 将数组成员通过一个分隔符合并成字符串

 var aList = [1,2,3,4];
 var res = aList.join('-');
 console.log(res);     //1-2-3-4     返回合并后的字符串
 console.log(aList);   //[1,2,3,4]   原数组。不变

10、forEach 遍历数据的方法

 // 作用:遍历数组
 arr.forEach(function(item,index){
   item 是数组里面的每个元素
   index 是数组的每个索引
 })

11、filter 数组筛选之后返回新数组

 // 作用:把数组中满足条件的元素,放到一个新的数组里面
 var result = arr.filter(function(item,index){
   return 条件
     // item就是当前遍历到的这个元素, index是这个元素索引
      return item > 20
 });

12、map 数据处理之后返回新数组

 var newArr = arr.map(function(item,index){
     item+=3;
     return item;
 })

1.3、String内置对象

1、字符串合并操作:“ + ”

 var num1 = 123;
 var str2 = 'def';
 console.log(str1+str2) // 123def

2、split() 把一个字符串按某种方式分隔成字符串组成的数组

 var str2 = 'a-b-c';
 var arr2 = str4.split('-');
 console.log(arr4) // ['a','b','c']

3、charAt() 获取字符串中的某一个字符

 var str3 = 'hello word'
 var res = str3.charAt(2)
 console.log(res)//l

4、indexOf() 查找字符串是否含有某字符(和数组一样的使用方式)

5、substring() 截取字符串 用法:substring(start,end)(不包括end)截取从star开始,到end之间的字符串

如果只传一个值,表示从这个位置开始,一致截取到字符串末端

 注意:  substring是以两个参数中较小一个作为起始位置,较大的参数作为结束位置
 var test = 'hello world';
 alert(test.substring(7,4)); //o w
 
 注意: 如果substring里面碰到负数,则干脆将负参数都直接转换为0
 var test = 'hello world'
 alert(test.substring(-3));     //hello world
 alert(test.slice(3,-4));       //lo w

6、substr(index,n) : 从index索引位置开始截取,截取n个字符

如果只传一个值,表示从这个位置开始,一致截取到字符串末端

7、toUpperCase() 字符串转大写8、toLowerCase() 字符串转小写9、replace(旧字符, 新字符) 该方法会返回一个新字符串,原字符串不改变

 var str9 = 'hello word'
 var res = str.replace('word','hhhhhhhh')
 console.log(res)// hello hhhhhhhh

1.4、Date内置对象

 var date = new Date();
 // 获取年份
 var year = date.getFullYear();
 console.log(year);
 // 获取月份 , 得到的月份是从0开始的 ,使用 0-11 表示 1-12 月
 var month = date.getMonth()+1;
 console.log(month);
 // 获取天 几号
 var day = date.getDate();
 console.log(day);
 // 获取星期数
 var d = date.getDay();
 // 获取小时
 var h = date.getHours();
 console.log(h);
 // 获取分钟
 var m = date.getMinutes();
 console.log(m);
 // 获取秒数
 var s = date.getSeconds();
 console.log(s);
 
 // 获取毫秒
 var ms = date.getMilliseconds();
 // 返回事件戳。1970年1月1日 0时0分0秒到现在的毫秒值
 // 最初计算机操作系统是 32 位,而时间也是用 32 位表示。
 // 最长时间是 68 年
 // 最早出现的 UNIX 操作系统考虑到计算机产生的年代和应用的时限
 // 综合取了 1970 年 1 月 1 日作为 UNIX TIME 的纪元时间
 var dateTime = date.getTime();
 
 // 把需要补0的先补上
 if (month < 10) {
     month = '0' + month;
 }
 if (day < 10) {
     day = '0' + day;
 }
 if (h < 10) {
     h = '0' + h;
 }
 if (m < 10) {
     m = '0' + m
 }
 if (s < 10) {
     s = '0' + s;
 }
 
 console.log("现在是: " + year + "-" + month + "-" + day + " " + h + ":" + m + ":" + s + ",星期" + d);

也可以生成一个指定的日期

 1.传入不同的年月日时分秒
 var d1 = new Date(2020,0,1,8,30,59); // 2020年1月1日 8:30:59
 
 2.传入一个指定的字符串
 var d2 = new Date('2020-01-01');
 
 3.传入一个 大的数字 -- 从1970年1月1日开始到某个日期的总共的毫秒数
 var d3 = new Date(1378594320999);

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...