Js函数的方法

Js函数的方法

		     **call()和apply()**

共同点:
- 这两个方法都是函数对象的方法,需要通过函数对象来调用
- 当对函数调用call()和apply()都会调用函数执行
- 在调用call()和apply()可以将一个对象指定为第一个参数
此时这个对象将会成为函数执行时的this
不同点:
- call()方法可以将实参在对象之后依次传递
- apply()方法需要将实参封装到一个数组中统一传递

Arguments
在调用函数时,浏览器每次都会传递进两个隐含的参数:
1.函数的上下文对象 this
2.封装实参的对象 arguments
Arguments的概念:arguments是一个类数组对象,它也可以通过索引来操作数据,也可以获取长度
作用: 在调用函数时,我们所传递的实参都会在arguments中保存
参数:- arguments.length可以用来获取实参的长度
- 我们即使不定义形参,也可以通过arguments来使用实参,
- arguments[0] 表示第一个实参
arguments[1] 表示第二个实参 。。。
属性:callee这个属性对应一个函数对象,就是当前正在指向的函数的对象
Date对象
在JS中使用Date对象来表示一个时间

		直接使用构造函数创建一个Date对象,则会封装为当前代码执行的时间
		var d = new Date();

创建一个指定的时间对象
需要在构造函数中传递一个表示时间的字符串作为参数
日期的格式 月份/日/年 时:分:秒
var d2 = new Date(“2/18/2011 11:10:30”);

getDate()
		     	- 获取当前日期对象是几日
		   
		var date = d2.getDate();

getDay()
- 获取当前日期对象时周几
- 会返回一个0-6的值
0 表示周日
1表示周一
。。。

		var day = d2.getDay();

getMonth()
d2 = new Date(“12/18/2011 11:10:30”);
- 获取当前时间对象的月份
- 会返回一个0-11的值
0 表示1月
1 表示2月
11 表示12月

		var month = d2.getMonth();

getFullYear()
- 获取当前日期对象的年份

		var year = d2.getFullYear();
		
		 
		     getTime()
		     	- 获取当前日期对象的时间戳
		     	- 时间戳,指的是从格林威治标准时间的1970年1月1日,0时0分0秒

作用在与方便计算机保存时间
- 计算机底层在保存时间时使用都是时间戳

		Math
	 Math和其他的对象不同,它不是一个构造函数,
	它属于一个工具类不用创建对象,它里边封装了数学运算相关的属性和方法
		属性

他的属性常用来返回一些数学上常用的数,pi,e。。

	Math.PI 表示的圆周率
	
		    console.log(Math.PI);
		**方法**
		
		     abs()可以用来计算一个数的绝对值
		   
		    console.log(Math.abs(-1));
		
		 
		     Math.ceil()
		     	- 可以对一个数进行向上取整,小数位只有有值就自动进1
		     Math.floor()
		     	- 可以对一个数进行向下取整,小数部分会被舍掉
		     Math.round()
		     	- 可以对一个数进行四舍五入取整
		   
		    console.log(Math.ceil(1.1));
		    console.log(Math.floor(1.99));
		    console.log(Math.round(1.4));
		
		 
		     Math.random()
		     	- 可以用来生成一个0-1之间的随机数
		      - 生成一个0-10的随机数
		     	- 生成一个0-x之间的随机数
		     		Math.round(Math.random()   x)
		     
		     	- 生成一个1-10
		     	- 生成一个x-y之间的随机数
		     		Math.round(Math.random()   (y-x)+x)
		   
		 for(var i=0 ; i<100 ; i++){
			    console.log(Math.round(Math.random()  *10));
			    console.log(Math.round(Math.random()   *20));
			
			    console.log(Math.round(Math.random()  * 9)+1);
			    console.log(Math.round(Math.random()  * 8)+2);
			
			    生成1-6之间的随机数
			console.log(Math.round(Math.random()  * 5+1));
		}  
		
		 
		     max() 可以获取多个数中的最大值
		     min() 可以获取多个数中的最小值
		   
		
		var max = Math.max(10,45,30,100);
		var min = Math.min(10,45,30,100);
		    console.log(min);
		
		 
		     Math.pow(x,y)
		     	返回x的y次幂
		   
		
		    console.log(Math.pow(12,3));
		
		 
		     Math.sqrt()
		      用于对一个数进行开方运算
		   
		console.log(Math.sqrt(2));


**包装类**

在JS中为我们提供了三个包装类,通过这三个包装类可以将基本数据类型的数据转换为对象
String()
- 可以将基本数据类型字符串转换为String对象
Number()
- 可以将基本数据类型的数字转换为Number对象
Boolean()
- 可以将基本数据类型的布尔值转换为Boolean对象
String相关方法
在底层字符串是以字符数组的形式保存的,所以它可以用数组的一些方法

length属性
- 可以用来获取字符串的长度

		    console.log(str.length);
		  
		
		 
		     charAt()
		     	- 可以返回字符串中指定位置的字符
		     	- 根据索引获取指定的字符	
		   
		str = "中Hello Atguigu";
		
		var result = str.charAt(6);
		
		 
		     charCodeAt()
		     	- 获取指定位置字符的字符编码(Unicode编码)
		
		 
		     concat()
		     	- 可以用来连接两个或多个字符串
		     	- 作用和+一样
		   
		result = str.concat("你好","再见");
		
		 
		     indexof()
		     	- 该方法可以检索一个字符串中是否含有指定内容
		     	- 如果字符串中含有该内容,则会返回其第一次出现的索引
		     		如果没有找到指定的内容,则返回-1
		     	- 可以指定一个第二个参数,指定开始查找的位置
		     
		     lastIndexOf();
		     	- 该方法的用法和indexOf()一样,
		     		不同的是indexOf是从前往后找,
		     		而lastIndexOf是从后往前找
		     	- 也可以指定开始查找的位置
		   
		
		str = "hello hatguigu";
		
		result = str.indexOf("h",1);
		
		result = str.lastIndexOf("h",5);
		
		 
		     slice()
		     	- 可以从字符串中截取指定的内容
		     	- 不会影响原字符串,而是将截取到内容返回
		     	- 参数:
		     		第一个,开始位置的索引(包括开始位置)
		     		第二个,结束位置的索引(不包括结束位置)
		     			- 如果省略第二个参数,则会截取到后边所有的
		     		- 也可以传递一个负数作为参数,负数的话将会从后边计算
		   
		str = "abcdefghijk";
		
		result = str.slice(1,4);
		result = str.slice(1,-1);
		
		 
		     substring()
		     	- 可以用来截取一个字符串,可以slice()类似
		     	- 参数:
		     		- 第一个:开始截取位置的索引(包括开始位置)
		     		- 第二个:结束位置的索引(不包括结束位置)
		     		- 不同的是这个方法不能接受负值作为参数,
		     			如果传递了一个负值,则默认使用0
		     		- 而且他还自动调整参数的位置,如果第二个参数小于第一个,则自动交换
		   
		
		result = str.substring(0,1);
		
		 
		     substr()
		     	- 用来截取字符串
		     	- 参数:
		     		1.截取开始位置的索引
		     		2.截取的长度
		   
		
		str = "abcdefg";
		
		result = str.substr(3,2);
		
		 
		     split()
		     	- 可以将一个字符串拆分为一个数组
		     	- 参数:
		     		-需要一个字符串作为参数,将会根据该字符串去拆分数组
		   
		str = "abcbcdefghij";
		
		result = str.split("d");
		
		 
		     如果传递一个空串作为参数,则会将每个字符都拆分为数组中的一个元素
		   
		result = str.split("");
		
		    console.log(Array.isArray(result));
		    console.log(result[0]);
		console.log(result);
		
		
		str = "abcdefg";
		
		 
		     toUpperCase()
		     	- 将一个字符串转换为大写并返回
		   
		result = str.toUpperCase();
		
		str = "ABCDEFG";
		
		 
		     toLowerCase()
		     	-将一个字符串转换为小写并返回
		   
		result = str.toLowerCase();
		
		    console.log(result);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值