总结js函数相关知识点


Posted in Javascript onFebruary 27, 2018

要知道,在js中,引用类型是一种数据结构,包含5种引用类型,分别是Object,data,Array,re请输入代码gExp,Function。今天我们就说Function这种数据结构。

在js种函数实际上是对象,每个函数都是Function类型的实例。和其他引用类型一样,都具有属性和方法。

1. 函数定义有几种方法

1)函数声明语法定义

function sum(num1,num2){
  return num1+num2;
 }

2)函数表达式

注意函数表达式后边有一个分号;

var sum=function(num1,num2){
   return num1+num2;
}

使用Function 构造函数

使用构造函数可以接收任意数量的参数,但最后一个参数始终被看成是函数体,而前面的参数则枚举出了参数

var sum=new Function("num1","num2","return num1+num2")

当然第三种方法不友好,也不推荐。

函数名仅仅是指向函数的指针,所以函数名与包含对象指针的其他变量没有什么不同。也就是说一个函数可能会有多个名字。
在这里函数声明和函数表达式有什么区别呢?

解析器在向执行环境中加载数据的时候,对函数声明和函数表达式是不一样的。解析器首先会读取函数声明,并且使得这段函数声明代码在任何代码之前都可调用。这就是我们平时所说的函数声明提升。函数表达式不一样,他必须等到函数解析器执行到他所在的代码块的时候,才会被真正的执行。比较下面2个例子

console.log(sum(10,10));

function sum(n1,n2){
  return n1+n2;
}

以上代码会正常执行

再看!

console.log(sum(10,10));

var sum=function(n1,n2){
  return n1+n2;
}

以上执行器就会报错!

2.函数没有重载

如果声明了2个同名函数,结果是后面的函数覆盖了前面的函数。

function sun(a){
 return a+100;
}
function sun(a){
 return a+200;
}

var result=sum(2)//202

3.函数的内部属性

包括this,arguments

具体不再叙述了

4.函数的属性和方法

函数有2个属性,length和prototype

length表示函数希望接收命名参数的个数。

function a(name){
 //todo
}
function b(name,age){
 //todo
}
function c(){
 //todo
}

a.length //1
b.length //2
c.length //0

prototype属性对于引用类型来说很重要,会有专门讲解,此处不再这赘述。

每个函数都包含2个非继承的方法 apply,call

这两个方法的用途都是在特定的作用域中调用函数,其实就是设置函数体内的this指代的值。

首先。apply()方法接收2个参数,一个是函数运行的作用域,另一个是参数数组,第二个参数可以是数组的实例,也可以是arguments.

function sum(num1,num2){
  return num1+num2;
}

function test1(a,b){
  return sum.apply(this,arguments);
}

function test2(c,d){
  return sum.apply(this.[c,d]);
}

console.log(test1(1,1)) //2

console.log(test2(1,1)) //2

call方法和apply方法没有多大的区别。区别就是call方法的第二个参数必须得传递的参数一个个列举出来。

使用call和apply来扩充作用域最大的好处就是对象不和任何方法耦合

Javascript 相关文章推荐
070823更新的一个[消息提示框]组件 兼容ie7
Aug 29 Javascript
jquery实现控制表格行高亮实例
Jun 05 Javascript
JS实现仿中关村论坛评分后弹出提示效果的方法
Feb 23 Javascript
javascript控制台详解
Jun 25 Javascript
JavaScript判断undefined类型的正确方法
Jun 30 Javascript
vue-resource 拦截器使用详解
Feb 21 Javascript
利用node 判断打开的是文件 还是 文件夹的实例
Jun 10 Javascript
微信小程序自定义组件components(代码详解)
Oct 21 Javascript
Vue项目中使用jsonp抓取跨域数据的方法
Nov 10 Javascript
jquery实现弹窗(系统提示框)效果
Dec 10 jQuery
jQuery+PHP+Ajax实现动态数字统计展示功能
Dec 25 jQuery
javascript 代码是如何被压缩的示例代码
May 06 Javascript
详解jQuery中的isPlainObject()使用方法
Feb 27 #jQuery
详解Vue Elememt-UI构建管理后台
Feb 27 #Javascript
详解react-native WebView 返回处理(非回调方法可解决)
Feb 27 #Javascript
Vue2.5通过json文件读取数据的方法
Feb 27 #Javascript
vue2.5.2使用http请求获取静态json数据的实例代码
Feb 27 #Javascript
jQuery幻灯片插件owlcarousel参数说明中文文档
Feb 27 #jQuery
关于ES6箭头函数中的this问题
Feb 27 #Javascript
You might like
php visitFile()遍历指定文件夹函数
2010/08/21 PHP
PHP获取一年中每个星期的开始和结束日期的方法
2015/02/12 PHP
PHP书写格式详解(必看)
2016/05/23 PHP
Jquery实现无刷新DropDownList联动实现代码
2010/03/08 Javascript
jQuery的实现原理的模拟代码 -4 重要的扩展函数 extend
2010/08/03 Javascript
如何将网页表格内容导入excel
2014/02/18 Javascript
js设置function参数默认值(适合没有传参情况)
2014/02/24 Javascript
深入理解JavaScript系列(25):设计模式之单例模式详解
2015/03/03 Javascript
JS 动态加载js文件和css文件 同步/异步的两种简单方式
2016/09/23 Javascript
解决浏览器会自动填充密码的问题
2017/04/28 Javascript
Vue2几种常见开局方式详解
2017/09/09 Javascript
关于jQuery里prev()的简单操作代码
2017/10/27 jQuery
JS中实现隐藏部分姓名或者电话号码的代码
2018/07/17 Javascript
jQuery滑动效果实现方法分析
2018/09/05 jQuery
搭建基于express框架运行环境的方法步骤
2018/11/15 Javascript
浅谈js闭包理解
2019/04/01 Javascript
node koa2 ssr项目搭建的方法步骤
2020/12/11 Javascript
[01:45]绝对公平!DOTA2队长征召模式详解
2014/04/25 DOTA
跟老齐学Python之不要红头文件(1)
2014/09/28 Python
Windows下PyMongo下载及安装教程
2015/04/27 Python
Python实现对excel文件列表值进行统计的方法
2015/07/25 Python
Python实现将一个大文件按段落分隔为多个小文件的简单操作方法
2017/04/17 Python
Python实现KNN邻近算法
2021/01/28 Python
Python线性回归实战分析
2018/02/01 Python
python解析命令行参数的三种方法详解
2019/11/29 Python
Python中文分词库jieba,pkusegwg性能准确度比较
2020/02/11 Python
Python qrcode 生成一个二维码的实例详解
2020/02/12 Python
Python多线程正确用法实例解析
2020/05/30 Python
大专毕业生自我鉴定
2013/11/21 职场文书
四年级语文教学反思
2014/02/05 职场文书
怎样拟定创业计划书
2014/05/01 职场文书
2014年仓库保管员工作总结
2014/12/03 职场文书
亲属关系公证书样本
2015/01/23 职场文书
自我检讨书范文
2015/01/28 职场文书
2019年妇科护士的自我鉴定(3篇)
2019/09/26 职场文书
python数字图像处理之图像的批量处理
2022/06/28 Python