JavaScript之 ------ 函数(一般函数、动态函数、匿名函数)
函数

一、一般函数

1、格式:

function 函数名(形式参数...)

{

执行语句;

return 返回值;

}

函数是多条执行语句的封装体,只有被调用才会被运行。

注意:调用有参数的函数,但没有给其传值,函数一样可以运行,或者调用没有参数的函数,给其传值,该函数也一样运行。

说的简单点:只要写了函数名后面跟了一对小括号,该函数就会运行。

2、函数虽然定义时是声明成两个参数,但调用时却是可以传入任意个

例:

1
2
3
<span style="font-size:14px;">function show(x,y){
         alert(x+:+y);
     }</span>
show(4,8); 结果:4:8

show(4);结果:4:undefined

show(); 结果:undefined:undefined

show(4,8,89); 结果:4:8

综上的例子,Js当中的函数是不存在重载的。如果有,一定就通配所有的了。

3、每个函数中,存在一个 默认的数组arguments ,里面存储着本次调用时传入的所有实参

1
2
<span style="font-size:14px;">function show2(x,y){
         for(var i=0; i</arguments.length;i++){></span>

结果:1 2 3 45

4、函数在调用时的其他写法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<span style="font-size:14px;"><script type=text/javascript>
      function getSum(){
          return 100;
      }
      var sum = getSum();
     // alert(sum); //结果:100
    
      var sum2 = getSum; //相当于java当中的 引用捆绑
      //alert(getSum); //结果:getSum.toString()
      // alert(sum2); //结果:sum2.toString(),也就是getSum.toString()
      //alert(sum2()); //等价于调用:getSum()
       
      function show2(){
          alert(kkkl);
      }
      alert( show2() ); //先弹出“kkkl”,再弹出“undefined”。因为里面的函数没有return值,而外面的函数要用变量去接,结果相当于变量没赋值就输出
       
   </script></span>

二、动态函数

利用Js当中内置的对象Function来构造一个函数,构造方法中的第1个参数是“形参”,第2个参数是“函数体”。

该思想类似于Java当中的类反射。我们平时写函数时通常不用,但关键的地方一写,整个程序的功能会变得很活。

1
2
3
<span style="font-size:14px;">var add = new Function(x,y, var sum; sum=x+y;return sum;);
var s = add(100,39);
alert(s=+s);</span>

三、匿名函数

格式:function(){...}

例:

1
2
var demo = function(){...}
demo();

通常在定义事件属性的行为时较为常用。

例:

1
2
3
4
5
function test()
{
alert(“load ok”);
}
window.onload = test;

可以写成匿名函数的形式:

1
2
3
4
window.onload = function()
{
alert(“load ok”);
}

匿名函数就是一种简写格式。

四、函数调用

function.js

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
      //1 取最大值:输出给定数组当中值最大的元素
      //函数定义
      function getMax(arr){
          var max=0;//记下标
          for(var x=1; xarr[max]){
                  max = x;
              }
          }
          return arr[max];
      }
       
     
      //2 数组排序
      //函数定义
      function sortArray(arr){
          for(var x=0; xarr[y]){
                      swap(arr,x,y);
                  }
              }
          }
      }
      //辅助函数,用于交换数组中的两个元素
      function swap(arr,x,y){
          var temp = arr[x];
          arr[x] = arr[y];
          arr[y] = temp;
      }
      
       
      //3 模拟Java当中的System.out.println()
      function println(str){
          document.write( str +
);
      }
       
       
      //4 在数组当中查找元素(若存在则返回该元素的位置,否则返回-1)
      function searchElement(arr,key){
          for(var x=0; x>1;
              if(key>arr[mid]){
                  min=mid+1;
              }else if(key调用:<pre class="brush:java;"></pre>
<script type=text/javascript src=functions.js>
    </script><script type=text/javascript>
       //1 函数调用
      var arr=[133,-22,33,43,1211];
      var mValue = getMax(arr);
      //alert(mValue=+ mValue);
    
       //2函数调用
      document.write(排序前:+arr +<br>); // println(arr);
      sortArray(arr);
      document.write(排序后:+arr);
       
      //3 函数调用
      println();
      println(arr);
       
      //4 函数调用
      var a=searchElement(arr,133);
      //alert(a);
       
      //5 函数调用
      var b=binarySearch(arr,-2);
      //alert(b);
       
      //6 函数调用
      reverseArray(arr);
      println(arr);
       
   </script></arr[mid]){></arr.length;></arr.length-1;></arr.length;>

 

JavaScript之 ------ 函数(一般函数、动态函数、匿名函数)的更多相关文章

  1. 洗礼灵魂,修炼python(25)--自定义函数(6)—从匿名函数进阶话题讲解中解析“函数式编程”

    匿名函数进阶 前一章已经说了匿名函数,匿名函数还可以和其他内置函数结合使用 1.map map():映射器,映射 list(map(lambda x:x*2,range(10))) #把range产生 ...

  2. js循环函数中的匿名函数和闭包问题(匿名函数要用循环中变量的问题)

    js循环函数中的匿名函数和闭包问题(匿名函数要用循环中变量的问题) 一.总结 需要好好看下面代码 本质是因为匿名函数用到了循环中的变量,而普通方式访问的话,匿名函数的访问在循环之后,所以得到的i是循环 ...

  3. JavaScript中的函数和C#中的匿名函数(委托、lambda表达式)

    在js中function是一个一个引用类型,所以可以出现这样的代码: 'use strict'; var compare=function(value1, value2) { if (value1&l ...

  4. Python的函数式编程-传入函数、排序算法、函数作为返回值、匿名函数、偏函数、装饰器

    函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. ...

  5. JS——变量和函数的预解析、匿名函数、函数传参、return

    JS解析过程分为两个阶段:编译阶段.执行阶段.在编译阶段会将函数function的声明和定义都提前,而将变量var的声明提前,并将var定义的变量赋值为undefined. 匿名函数: window. ...

  6. python基础-4 函数参数引用、lambda 匿名函数、内置函数、处理文件

    上节课总结 1.三元运算 name=“name1”if 条件 else “name2” 2.深浅拷贝 数字.字符串 深浅,都一样 2.其他 浅拷贝:只拷贝第一层 深拷贝:不拷贝最后一层 3.set集合 ...

  7. python函数知识点(详解匿名函数)

    Python函数是组织好的.单一的.具有独立功能模块的代码块. 函数能提高应用的模块性,和代码的重复利用率.Python提供了许多内建函数,比如print().但你也可以自己创建函数,这被叫做用户自定 ...

  8. 6.1 函数的返回值、匿名函数lambda、filter函数、map函数、reduce函数

      函数的返回值: 函数一旦执行到   return,函数就会结束,并会返回return 后面的值,如果不使用显式使用return返回,会默认返回None . return None可以简写为   r ...

  9. python函数知识二 动态参数、函数的注释、名称空间、函数的嵌套、global,nonlocal

    6.函数的动态参数 *args,**kwargs:能接受动态的位置参数和动态的关键字参数 *args -- tuple *kwargs -- dict 动态参数优先级:位置参数 > 动态位置参数 ...

  10. Python之路-函数基础&局部变量与全局变量&匿名函数&递归函数&高阶函数

    一.函数的定义与调用 函数:组织好的.可重复使用的.用户实现单一或者关联功能的代码段.函数能够提高应用的模块性和代码的重复利用率.Python提供了很多内置的函数,比如len等等,另外也可以根据自己的 ...

随机推荐

  1. VB - 循环

    循环控制语句有for……next循环.for……each循环.do……while循环.do……until循环.while循环五种形式. 1. 在使用循环控制语句前,首先要对循环条件进行判断,如果循环次 ...

  2. C++中逻辑操作符的重载分析

    1,逻辑运算符的原生语义: 1,操作数只有两种值(true 和 false): 1,C 语言中只有非 0 和 0: 2,逻辑表达式不用完全计算就能确定最终值: 1,短路规则: 3,最终结果只能是 tr ...

  3. 阿里云 消息队列mq

    使用阿里云消息队列 控制台地址:http://ons.console.aliyun.com/#/home/topic Demo: 支付消息mq工厂类: public class DfacePayCon ...

  4. fiddler抓取手机端的数据流量包

    1.首先下载安装fiddler 2.然后打开fiddler,进入到tools-->options-->connections 3.然后进入到https 4.设置完成后,查找本机ip 然后打 ...

  5. 51.Lowest Common Ancestor of a Binary Tree(二叉树的最小公共祖先)

    Level:   Medium 题目描述: Given a binary tree, find the lowest common ancestor (LCA) of two given nodes ...

  6. split slice splice的简单区别

    split slice splice的简单区别 split: 分割 //字符串方法 string.split let str = 'hello world'; //str.split('') 以什么东 ...

  7. number框

    因为系统的number框无法设置样式,所以休息无聊时写了一个简单的模拟number框的插件,效果不是很完善,有一些功能可能没注意到 // 简单的模拟number框插件 // 布局: // <di ...

  8. SET CONSTRAINTS - 设置当前事务的约束模式

    SYNOPSIS SET CONSTRAINTS { ALL | name [, ...] } { DEFERRED | IMMEDIATE } DESCRIPTION 描述 SET CONSTRAI ...

  9. K8S操作

    一.K8Spods操作 kubectl delete all --all //删除 所有pods

  10. Java集合类框架的最佳实践有哪些

    根据应用的需要正确选择要使用的集合的类型对性能非常重要,比如:元素的大小是固定的,而且能事先知道,我们就应该用Array而不是ArrayList. 有些集合类允许指定初始容量.因此,如果我们能估计出存 ...