JavaScript基础07--Math、Array、String内置对象介绍

本文介绍了JavaScript中的内置对象,包括Math对象的数学常数和函数、Date对象的日期和时间处理、Array对象的数组操作方法以及String对象的字符串处理方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

内置对象

JavaScript中的对象分为3种:内置对象、自定义对象、浏览器对象

JavaScript 提供多个内置对象:Math/Array/Date…

对象只是带有属性和方法的特殊数据类型。

Math对象

Math对象具有数学常数和函数的属性和方法,都是以静态成员的方式提供

跟数学相关的运算来找Math中的成员(求绝对值,取整,获取随机数等等)

Math.PI						// 圆周率
Math.random()				// 生成一个0到1之间的随机小数(含0,不含1)
Math.floor()/Math.ceil()	 // 向下取整/向上取整
	Math.floor(3.8);	//3
	Math.floor(3.3);	//3
	Math.floor(3);		//3
	Math.floor(-3.3);	//-4
Math.round()				// 取整,四舍五入
Math.abs()					// 绝对值
Math.max()/Math.min()		 // 求最大和最小值
Math.min.apply(Math,arr)    //求数组中的最小值, 参数1可以写null,参数2 传入一个数组
Math.sin()/Math.cos()		 // 正弦/余弦
Math.pow()/Math.sqrt()	 // 求指数次幂/求平方根
	Math.pow(x, y)	//求x的y次方
	Math.pow(3,2);	//结果就是9(3的2次方
	Math.pow(2,3);	//8(2的3次方)
	Math.sqrt(x);	

Date对象

创建 Date 实例用来处理日期和时间。Date 对象基于1970年1月1日(世界标准时间)起的毫秒数。

获取当前时间,UTC世界时间,距1970年1月1日(世界标准时间)起的毫秒数
var now = new Date();
console.log(now.valueOf());	// 获取距1970年1月1日(世界标准时间)起的毫秒数

Date构造函数的参数
1. 毫秒数 1498099000356		new Date(1498099000356)
2. 日期格式字符串  '2015-5-1'	 new Date('2015-5-1')
3. 年、月、日……				  new Date(2015, 4, 1)   // 月份从0开始
  • 获取日期的毫秒形式

    var now = new Date();
    // valueOf用于获取对象的原始值
    console.log(date.valueOf())	
    
    // HTML5中提供的方法,有兼容性问题
    var now = Date.now();	
    
    // 不支持HTML5的浏览器,可以用下面这种方式
    var now = + new Date();			// 调用 Date对象的valueOf() 
    
  • 日期格式化方法

    .toString()		// 转换成字符串
    .valueOf()		// 获取毫秒值
    
  • 获取日期指定部分

    .getTime()  	  // 返回毫秒数和valueOf()结果一样
    .getMilliseconds() 
    .getSeconds()  // 返回0-59
    .getMinutes()  // 返回0-59
    .getHours()    // 返回0-23
    .getDay()      // 返回星期几 0周日   6周6
    .getDate()     // 返回当前月的第几天
    .getMonth()    // 返回月份,***从0开始***
    .getFullYear() //返回4位的年份  如 2016
    

Array对象

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

    • 字面量方式: [值1,值2,值3,… ]

    • 实例化方式: new Array(值1,值2,值3,… )

      // 1. 使用构造函数创建数组对象
      // 创建了一个空数组
      var arr = [];
      var arr = new Array();
      // 创建了一个数组,里面存放了3个字符串
      var arr = new Array('zs', 'ls', 'ww');
      // 创建了一个数组,里面存放了4个数字
      var arr = new Array(1, 2, 3, 4);
      
      // 2. 使用字面量创建数组对象
      var arr = [1, 2, 3];
      
      // 获取数组中元素的个数
      console.log(arr.length);
      
  • 检测一个对象是否是数组

    • instanceof
    • Array.isArray() HTML5中提供的方法,有兼容性问题
      函数的参数,如果要求是一个数组的话,可以用这种方式来进行判断
  • toString()/valueOf()

    • .toString() 把数组转换成字符串,逗号分隔每一项
    • .valueOf() 返回数组对象本身
  • 数组属性
    .length 获取数组的长度(元素个数),实际就是最大下标加1;

  • 数组常用方法

    1 栈操作(先进后出)
    .push()		//将一个或多个数据加入到数组的末端
    .pop() 		//取出数组中的最后一项,修改length属性
    
    2 队列操作(先进先出)
    .unshift() 	//在数组最前面插入项,返回数组的长度
    .shift()	//取出数组中的第一个元素,修改length属性
    
    3 排序方法
    .reverse()	//翻转数组
    
    4 操作方法
    .concat()  	//把参数拼接到当前数组,返回一个新数组,当前数组不会改变。
    .slice(start,end) 	//从当前数组中截取一个新的数组,不影响原来的数组,参数start从0开始,end从1开始,但是不包括1
    
    .splice(start,deleteCount,options)	//删除或替换当前数组的某些项目,参数start(开始位置), deleteCount(需要截取的个数), options(要替换的项目),返回的是被截取的数据。
    
    5 位置方法
    .indexOf(值);//从开始位置往后找数组中的值,找到返回的是该值的第一个位置,如果没找到返回-1;
    .lastIndexOf(值) ;  //从结束位置往前找数组中的值,找到返回的是该值的第一个位置,如果没找到返回-1;
    
    6 迭代方法 不会修改原数组(可选)  html5
    .forEach() //对数组进行遍历
    var a = [1,2,3];
    a.forEach(function(i){
        console.log(i); //输出数组中的每一个值 i代表数组中的每一个值
    });
    
    7 方法将数组的所有元素连接到一个字符串中。
    .join() //将数组转换成字符串,返回一个字符串,原数组不变。
    
  • 清空数组

    // 方式1 推荐 
    arr = [];
    // 方式2 
    arr.length = 0;
    // 方式3
    arr.splice(0, arr.length);
    

String对象

  • 创建字符串对象

    var str = new String('Hello World');
    
    // 获取字符串中字符的个数
    console.log(str.length);
    
  • 字符串对象的常用方法

    1 字符方法
    charAt()    	//获取指定位置处字符,原字符串不会改变
    charCodeAt()  	//获取指定位置处字符的ASCII码
    str[0]   		//HTML5,IE8+支持 和charAt()等效
    2 字符串操作方法
    concat()   		//拼接字符串,等效于+,+更常用
    slice(start,end)*    		//从start位置开始,截取到end位置,end取不到
      'abcdefg'.slice(2,5);	//结果:'cde'
    substring() 	//从start位置开始,截取到end位置,  end取不到
      同slice方法
      
    substr(start,length)*   		//从start位置开始,截取length个字符,如果没有length参数,则截取到最后
    	'abcdefg'.substr(2,4);	//'cdef'
    	'abcdefg'.substr(2);	//'cdefg'
    3 位置方法
    
    indexOf()*   	//返回指定内容在原字符串中的位置,如果想要让这个方法有意义,调用的字符串必须大于传入的字符串。-1代表没有这个字符。
      'abcdefgabc'.indexOf('b');	//1
    
    lastIndexOf() 	//从后往前找,只找第一个匹配的字符的位置
      'abcdefgabc'.lastIndexOf('b');	//8
    
    4 去除空白   
    trim()  		//去除字符串前后的空白(包括空格,回车符,换行符,tab符)
      '  ab  cd  ef  '.trim();	//'ab  cd  ef'
    
    5 大小写转换方法
    toUpperCase() 	//转换为大写
    toLowerCase() 	//转换为小写
    
    6 其它
    search() 		//查找,返回找到的位置
      'abcdefgabc'.search('cd');	//2;	//虽然有两个字符,但都只算最前面的字符的位置
    
    replace()		//替换,注意:一次只能替换一个
      'abcdefgabc'.replace('b', "B");		//'aBcdefgabc'
    
    split()*			//将字符串以指定的字符分割为数组
      'abcdefgabc'.split('b');	//结果是数组:['a','cdefga','c']
      'abcdefgabc'.split('defg');	//结果是数组:['abc','abc']
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值