总结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 相关文章推荐
各种效果的jquery ui(接口)介绍
Sep 17 Javascript
表单元素的submit()方法和onsubmit事件应用概述
Feb 01 Javascript
javascript-简单的计算器实现步骤分解(附图)
May 30 Javascript
如何获取select下拉框的值(option没有及有value属性)
Nov 08 Javascript
JS按字节截取字符长度实例
Nov 20 Javascript
js生成的验证码的实现与技术分析
Sep 17 Javascript
jQuery中$.extend()用法实例
Jun 24 Javascript
jQuery中$this和$(this)的区别介绍(一看就懂)
Jul 06 Javascript
JavaScript获取客户端IP的方法(新方法)
Mar 11 Javascript
JavaScript学习笔记之创建对象
Mar 25 Javascript
详解微信小程序开发之——wx.showToast(OBJECT)的使用
Jan 18 Javascript
微信小程序实现渐入渐出动画效果
Jun 13 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面向对象编程快速入门
2006/10/09 PHP
php下检测字符串是否是utf8编码的代码
2008/06/28 PHP
php中filter函数验证、过滤用户输入的数据
2014/01/13 PHP
php中获取主机名、协议及IP地址的方法
2014/11/18 PHP
如何在旧的PHP系统中使用PHP 5.3之后的库
2015/12/02 PHP
php数据库操作model类(使用__call方法)
2016/11/16 PHP
让任务管理器中的CPU跳舞的js代码
2008/11/01 Javascript
jQuery EasyUI 的EasyLoader功能介绍
2010/09/12 Javascript
jQuery 选择器、DOM操作、事件、动画
2010/11/25 Javascript
javascript各浏览器中option元素的表现差异
2011/04/07 Javascript
Javascript 八进制转义字符(8进制)
2011/04/08 Javascript
jQuery 1.8 Release版本发布了
2012/08/14 Javascript
有效提高JavaScript执行效率的几点知识
2015/01/31 Javascript
JS实现鼠标滑过链接改变网页背景颜色的方法
2015/10/20 Javascript
PassWord输入框代码分享
2016/06/07 Javascript
Asp.Net之JS生成分页条的方法
2016/11/23 Javascript
Jquery EasyUI $.Parser
2017/06/02 jQuery
解决nodejs的npm命令无反应的问题
2018/05/17 NodeJs
Nodejs中的JWT和Session的使用
2018/08/21 NodeJs
浅析vue 函数配置项watch及函数 $watch 源码分享
2018/11/22 Javascript
Nodejs模块的调用操作实例分析
2018/12/25 NodeJs
[02:02]2018DOTA2亚洲邀请赛Mineski赛前采访
2018/04/04 DOTA
python和shell实现的校验IP地址合法性脚本分享
2014/10/23 Python
Python列表list操作符实例分析【标准类型操作符、切片、连接字符、列表解析、重复操作等】
2017/07/24 Python
python爬虫之模拟登陆csdn的实例代码
2018/05/18 Python
python实现简单的单变量线性回归方法
2018/11/08 Python
Python3实现获取图片文字里中文的方法分析
2018/12/13 Python
django 消息框架 message使用详解
2019/07/22 Python
python中实现栈的三种方法
2020/12/19 Python
澳大利亚在线时尚精品店:Hello Molly
2018/02/26 全球购物
施工安全责任书
2014/04/14 职场文书
优秀教导主任事迹材料
2014/05/09 职场文书
银行服务明星推荐材料
2014/05/29 职场文书
2015年119消防宣传日活动总结
2015/03/24 职场文书
人事部:年度述职报告范文
2019/07/12 职场文书
讨论nginx location 顺序问题
2022/05/30 Servers