JavaScript函数

函数是什么

函数是一种工具,他是用来将一些重复的功能封装到一起,之后去调用即可

第一种:
function 函数名() { }
函数名();
第二种:
var a = function(){ }
a();
第三种:
var a = new Function();
tip:因为创建方式不够直观并且使用不便,所以基本不使用。

函数返回值

return : 将函数内部的值返回到函数的外部。从而实现在函数外部使用值的作用

tip : 如果一个函数没有返回值,结果为Undefined。

return特点:

  1. return语句后面的代码将不能执行

  2. 在一个函数中同时生效的return语句只能有一个。

  3. return只能返回一个结果而不能返回一段代码。

递归函数

递归函数是在一个函数通过名字调用自身的情况下构成的

function factorial(num){
if(num <= 1){
return 1;
}else{
return num * factorial(num-1);
}
}

匿名函数(anoymous)

创建一个函数并将它赋给变量,这种情况下创建的函数叫做匿名函数,因为function后面没有标识符,匿名函数的name属性时空字符串。(匿名函数有时也叫拉姆达函数)。

Tip : 在使用函数表达式的时候,最好不要写函数名字。即使写了,这个函数名字在函数外部也使用不了,只能在内部使用。

//匿名函数
var anoymous = function(args){
// 函数体
}

自执行函数(通过匿名函数实现)

(function(){
// 函数体
})();

第一个括号的作用让函数变成表达式。

第二个括号作用是执行函数。

回调函数

把一个函数当作一个参数传递给另一个函数,并且在另一个函数中去调用这个函数,即为回调函数。

var fn1 = function(function(){ <!--函数体-->}){
// 函数体
}

闭包函数

函数对象可以通过作用域相互关联起来,函数体内部的变量都可以保存在函数作用域内,这种特性在计算机科学文献中称为闭包

function createFunctions(){
return function(){
return 'hello world';
}
}

Tip: 闭包的缺点

程序常驻内存,不会被销毁.若是造成循环利用就会导致内存泄漏

构造函数

除了null和undefined,所有的数据类型都可以通过构造函数的形式创造出来,并且都是对象类型。

Tip:在js中,除了null和undefined,一切皆对象

var str = new String("hello world");//构造函数实例化

构造函数两大类

  1. 系统内置构造函数

  2. 自定义构造函数(创建出一个对象)

注意事项

  1. 使用函数名需要采用大驼峰

  2. 变量接受不在是返回值,而不是构造函数创建出来的一个对象

  3. 构造函数一般不设置return

函数属性

arguments

arguments是一个类数组对象,传给函数的实参都会储存在arguments里。通过arguments加方括号使用

this

this对象是在基于函数的执行环境绑定的。

1.当函数被当作方法调用时。this等于那个对象
2.在事件处理函数中,this等于事件源
3.在普通函数中this等于windows

内存划分

栈(stack)

自动分配内存大小,由系统自动释放

Tip:存在栈中的数据不可改变

堆(heap)

动态分配内存空间,大小也不一定释放

作用

1.基础数据类型储存在栈中,数据大小确定,内存空间大小可以分配,直接安值存放,也
按值读取。 2.引用数据类型存在堆中,在栈中仅存储一个地址

javaScript入门(函数)的更多相关文章

  1. JavaScript入门-函数function(二)

    JavaScript入门-函数function(二) 递归函数 什么是递归函数? 递归简单理解就是,在函数体里,调用自己. //我们在求一个10的阶乘的时候,可能会这么做 //写一个循环 var to ...

  2. 05.Javascript——入门函数

    //定义函数的方法1 function abs(x) { if (x >= 0) { return x; } else { return -x; } } 上述abs()函数的定义如下: func ...

  3. 开心菜鸟系列----函数作用域(javascript入门篇)

      1 <!DOCTYPE html>   2 <html>   3 <script src="./jquery-1.7.2.js"></ ...

  4. 07.Javascript——入门高阶函数

    高阶函数英文叫Higher-order function..JavaScript的函数其实都指向某个变量.既然变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数 ...

  5. JavaScript入门篇 编程练习

    编程挑战 一.定义"改变颜色"的函数 提示: obj.style.color obj.style.backgroundColor 二.定义"改变宽高"的函数 提 ...

  6. (转)Javascript匿名函数的写法、传参、递归

    (原)http://www.veryhuo.com/a/view/37529.html (转)javascript匿名函数的写法.传参和递归 javascript匿名函数的写法.传参和递归 http: ...

  7. (转)javascript匿名函数的写法、传参和递归

    (原)http://www.veryhuo.com/a/view/37529.html (转)javascript匿名函数的写法.传参和递归 http://www.veryhuo.com 2011-0 ...

  8. 慕课网JavaScript入门篇课程笔记

    1.js注释很重要 单行注释,在注释内容前加符号 “//”. <script type="text/javascript"> document.write(" ...

  9. JavaScript入门基础

    JavaScript基本语法 1.运算符 运算符就是完成操作的一系列符号,它有七类: 赋值运算符(=,+=,-=,*=,/=,%=,<<=,>>=,|=,&=).算术运 ...

  10. JavaScript入门介绍(二)

    JavaScript入门介绍 [函数] 函数function 是Javascript的基础模块单元,用于代码的复用.信息影藏和组合调用. function a(){} 函数对象Function Lit ...

随机推荐

  1. 这 100 道 Python 题,拿去刷!!!

    2020年,学 Python 还有价值吗? 根据 2020 年 2 月的 TIOBE 编程语言排行榜显示,Python仍然稳居第三位. 此排行榜排名基于互联网上有经验的程序员. 课程和第三方厂商的数量 ...

  2. Bash脚本编程学习笔记07:循环结构体

    本篇中涉及到算术运算,使用了$[]这种我未在官方手册中见到的用法,但是确实可用的,在此前的博文<Bash脚本编程学习笔记03:算术运算>中我有说明不要使用,不过自己忘记了.大家还是尽量使用 ...

  3. 第1章 JavaScript 简介

    第1章 JavaScript 简介 1.1 JavaScript简史 1.2 JavaScript实现 1.2.1 ECMAScript 1.2.2 文档对象模型(DOM) 1.2.3 浏览器对象模型 ...

  4. Python中关于日期的计算总结

    1.获取当前时间的两种方法: 代码如下: import datetime,timenow = time.strftime("%Y-%m-%d %H:%M:%S")print now ...

  5. Linux安装ftp服务-详细步骤

    最近项目中用到了FTP服务器,于是整理了一份在Linux服务器上安装FTP的详细步骤供大家分享. 1.首先连接上自己的Linux服务器.我的Linux是CentOS 6 2.检查Linux服务器上是否 ...

  6. PTA Deque (C语言)

    A "deque" is a data structure consisting of a list of items, on which the following operat ...

  7. equals和==的使用

    1.equals的使用: 引用数据类型的比较:通常情况下比较的是引用数据类型下的栈中的地址,但当你重写了equals方法后就不一定了 User user1=new User("tom&quo ...

  8. css过渡——实现元素的飞入飞出

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. vsftp安装及配置

    一.安装Vsftp 1,安装 yum install vsftpd -y

  10. 【spring boot】SpringBoot初学(1) - Hello World

    前言 此文只是记录自己简单学习spring boot的笔记.所以,文章很多只是初步理解,可能存在严重错误. 一.Spring boot的初步理解 1.spring boot的目标 (摘自:spring ...