总结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 相关文章推荐
利用js跨页面保存变量做菜单的方法
Jan 17 Javascript
jQuery的写法不同导致的兼容性问题的解决方法
Jul 29 Javascript
jquery增加时编辑jqGrid(实例代码)
Nov 08 Javascript
angularJS提交表单(form)
Feb 09 Javascript
聊一聊JS中this的指向问题
Jun 17 Javascript
浅谈js算法和流程控制
Dec 29 Javascript
Vue系列:通过vue-router如何传递参数示例
Jan 16 Javascript
几种tab切换详解
Feb 03 Javascript
Linux使用Node.js建立访问静态网页的服务实例详解
Mar 21 Javascript
如何安装控制器JavaScript生成插件详解
Oct 21 Javascript
详解小程序之简单登录注册表单验证
May 13 Javascript
Moment.js实现多个同时倒计时
Aug 26 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
全国FM电台频率大全 - 19 广东省
2020/03/11 无线电
Mysql的GROUP_CONCAT()函数使用方法
2008/03/28 PHP
php字符串函数学习之substr()
2015/03/27 PHP
学习PHP的数组总结【经验】
2016/05/05 PHP
iis 7下安装laravel 5.4环境的方法教程
2017/06/14 PHP
PHP新特性详解之命名空间、性状与生成器
2017/07/18 PHP
PHP实现数组转JSon和JSon转数组的方法示例
2018/06/14 PHP
php解决安全问题的方法实例
2019/09/19 PHP
js中split函数的使用方法说明
2013/12/26 Javascript
解决bootstrap中modal遇到Esc键无法关闭页面
2015/03/09 Javascript
js实现仿Windows风格选项卡和按钮效果实例
2015/05/13 Javascript
JS实现新浪博客左侧的Blog管理菜单效果代码
2015/10/22 Javascript
jquery 表单验证之通过 class验证表单不为空
2015/11/02 Javascript
jQuery获取DOM节点实例分析(2种方式)
2015/12/15 Javascript
Bootstrap实现弹性搜索框
2016/07/11 Javascript
JavaScript计算器网页版实现代码分享
2016/07/15 Javascript
Bootstrap.css与layDate日期选择样式起冲突的解决办法
2017/04/07 Javascript
浅谈sass在vue注意的地方
2017/08/10 Javascript
Vue shopCart 组件开发详解
2018/01/26 Javascript
对vue事件的延迟执行实例讲解
2018/08/28 Javascript
vue router-link 默认a标签去除下划线的实现
2020/11/06 Javascript
Python创建系统目录的方法
2015/03/11 Python
Python删除windows垃圾文件的方法
2015/07/14 Python
用matplotlib画等高线图详解
2017/12/14 Python
Pycharm取消py脚本中SQL识别的方法
2018/11/29 Python
python 抓包保存为pcap文件并解析的实例
2019/07/23 Python
python线程池如何使用
2020/05/28 Python
Html5游戏开发之乒乓Ping Pong游戏示例(一)
2013/01/21 HTML / CSS
Currentbody德国站:健康与美容技术专家
2020/04/05 全球购物
OSPF有什么优点?为什么OSPF比RIP收敛快?
2013/02/13 面试题
优秀应届生推荐信
2013/11/09 职场文书
初三物理教学反思
2014/01/21 职场文书
护理医院见习报告
2014/11/03 职场文书
2015年世界环境日活动方案
2015/05/05 职场文书
IDEA 链接Mysql数据库并执行查询操作的完整代码
2021/05/20 MySQL
Django分页器的用法你都了解吗
2021/05/26 Python