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. 洛谷P2387 [NOI2014]魔法森林(LCT)

    魔法森林 题目传送门 解题思路 把每条路按照\(a\)的值从小到大排序.然后用LCT按照b的值维护最小生成树,将边按照顺序放入.如果\(1\)到\(n\)有了一条路径,就更新最小答案.这个过程就相当于 ...

  2. Linux环境下OpenSceneGraph的安装和配置

    1.在GitHub上下载OpenSceneGrpah的源码包,地址. 2.解压缩源码包并进入源码包; 3.安装所需的依赖库: 先输入命令: sudo apt-get install openscene ...

  3. C++异常处理的深入理解

    1,问题: 1,如果在 main 函数中抛出异常会发生什么? 1,不处理,则崩溃: 2,如果异常不处理,最后会传到哪里? 3,下面的代码输出什么? 4,异常的最终处理编程实验: #include &l ...

  4. 【目录】sql server 进阶篇系列

    随笔分类 - sql server 进阶篇系列 sql server 下载安装标记 摘要: SQL Server 2017 的各版本和支持的功能 https://docs.microsoft.com/ ...

  5. 背包九讲(Orz)

    P01: 01背包问题 题目 有\(N\)件物品和一个容量为\(V\)的背包.第\(i\)件物品的费用是\(c[i]\),价值是\(w[i]\).求解将哪些物品装入背包可使这些物品的费用总和不超过背包 ...

  6. webpack4入门到进阶案例实战课程

    愿景:"让编程不在难学,让技术与生活更加有趣" 更多教程请访问xdclass.net 第一章 webpack4前言 第一集 webpack4入门到进阶案例实战课程介绍 简介:讲述w ...

  7. spring静态资源配置

    优雅REST风格的资源URL不希望带 .html 或 .do 等后缀.由于早期的Spring MVC不能很好地处理静态资源,所以在web.xml中配置DispatcherServlet的请求映射,往往 ...

  8. GenXus学习笔记——Transaction的建立

    我们上次聊到 如何正确无误的的创建一个项目KB 那么这次我们就该聊一点实际的东西了(敲黑板( ̄▽ ̄))  上回书说道我们在创建完自己的KB后 该创建自己的数据库了 首先我们先创建创建一个表 但是创建之 ...

  9. websocket(python)

    1.websocket-server https://github.com/google/pywebsocket git clone https://github.com/google/pywebso ...

  10. 【机器学习实验】scikit-learn的主要模块和基本使用

    [机器学习实验]scikit-learn的主要模块和基本使用 引言 对于一些开始搞机器学习算法有害怕下手的小朋友,该如何快速入门,这让人挺挣扎的.在从事数据科学的人中,最常用的工具就是R和Python ...