JavaScript之 ------ 函数(一般函数、动态函数、匿名函数)
- JavaScript之 ------ 函数(一般函数、动态函数、匿名函数)
- 函数
-
一、一般函数
1、格式:
function 函数名(形式参数...)
{
执行语句;
return 返回值;
}
函数是多条执行语句的封装体,只有被调用才会被运行。
注意:调用有参数的函数,但没有给其传值,函数一样可以运行,或者调用没有参数的函数,给其传值,该函数也一样运行。
说的简单点:只要写了函数名后面跟了一对小括号,该函数就会运行。
2、函数虽然定义时是声明成两个参数,但调用时却是可以传入任意个
例:
123<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 ,里面存储着本次调用时传入的所有实参
12<span style="font-size:14px;">function show2(x,y){for(var i=0; i</arguments.length;i++){></span>结果:1 2 3 45
4、函数在调用时的其他写法
123456789101112131415161718<span style="font-size:14px;"><script type=text/javascript>function getSum(){return100;}var sum = getSum();// alert(sum); //结果:100var 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当中的类反射。我们平时写函数时通常不用,但关键的地方一写,整个程序的功能会变得很活。
123<span style="font-size:14px;">var add =newFunction(x,y, var sum; sum=x+y;returnsum;);var s = add(100,39);alert(s=+s);</span>三、匿名函数
格式:function(){...}
例:
12var demo = function(){...}demo();通常在定义事件属性的行为时较为常用。
例:
12345function test(){alert(“load ok”);}window.onload = test;可以写成匿名函数的形式:
1234window.onload = function(){alert(“load ok”);}匿名函数就是一种简写格式。
四、函数调用
function.js
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071//1 取最大值:输出给定数组当中值最大的元素//函数定义function getMax(arr){var max=0;//记下标for(var x=1; xarr[max]){max = x;}}returnarr[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;}elseif(key调用:<preclass="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之 ------ 函数(一般函数、动态函数、匿名函数)的更多相关文章
- 洗礼灵魂,修炼python(25)--自定义函数(6)—从匿名函数进阶话题讲解中解析“函数式编程”
匿名函数进阶 前一章已经说了匿名函数,匿名函数还可以和其他内置函数结合使用 1.map map():映射器,映射 list(map(lambda x:x*2,range(10))) #把range产生 ...
- js循环函数中的匿名函数和闭包问题(匿名函数要用循环中变量的问题)
js循环函数中的匿名函数和闭包问题(匿名函数要用循环中变量的问题) 一.总结 需要好好看下面代码 本质是因为匿名函数用到了循环中的变量,而普通方式访问的话,匿名函数的访问在循环之后,所以得到的i是循环 ...
- JavaScript中的函数和C#中的匿名函数(委托、lambda表达式)
在js中function是一个一个引用类型,所以可以出现这样的代码: 'use strict'; var compare=function(value1, value2) { if (value1&l ...
- Python的函数式编程-传入函数、排序算法、函数作为返回值、匿名函数、偏函数、装饰器
函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. ...
- JS——变量和函数的预解析、匿名函数、函数传参、return
JS解析过程分为两个阶段:编译阶段.执行阶段.在编译阶段会将函数function的声明和定义都提前,而将变量var的声明提前,并将var定义的变量赋值为undefined. 匿名函数: window. ...
- python基础-4 函数参数引用、lambda 匿名函数、内置函数、处理文件
上节课总结 1.三元运算 name=“name1”if 条件 else “name2” 2.深浅拷贝 数字.字符串 深浅,都一样 2.其他 浅拷贝:只拷贝第一层 深拷贝:不拷贝最后一层 3.set集合 ...
- python函数知识点(详解匿名函数)
Python函数是组织好的.单一的.具有独立功能模块的代码块. 函数能提高应用的模块性,和代码的重复利用率.Python提供了许多内建函数,比如print().但你也可以自己创建函数,这被叫做用户自定 ...
- 6.1 函数的返回值、匿名函数lambda、filter函数、map函数、reduce函数
函数的返回值: 函数一旦执行到 return,函数就会结束,并会返回return 后面的值,如果不使用显式使用return返回,会默认返回None . return None可以简写为 r ...
- python函数知识二 动态参数、函数的注释、名称空间、函数的嵌套、global,nonlocal
6.函数的动态参数 *args,**kwargs:能接受动态的位置参数和动态的关键字参数 *args -- tuple *kwargs -- dict 动态参数优先级:位置参数 > 动态位置参数 ...
- Python之路-函数基础&局部变量与全局变量&匿名函数&递归函数&高阶函数
一.函数的定义与调用 函数:组织好的.可重复使用的.用户实现单一或者关联功能的代码段.函数能够提高应用的模块性和代码的重复利用率.Python提供了很多内置的函数,比如len等等,另外也可以根据自己的 ...
随机推荐
- 洛谷P2387 [NOI2014]魔法森林(LCT)
魔法森林 题目传送门 解题思路 把每条路按照\(a\)的值从小到大排序.然后用LCT按照b的值维护最小生成树,将边按照顺序放入.如果\(1\)到\(n\)有了一条路径,就更新最小答案.这个过程就相当于 ...
- Linux环境下OpenSceneGraph的安装和配置
1.在GitHub上下载OpenSceneGrpah的源码包,地址. 2.解压缩源码包并进入源码包; 3.安装所需的依赖库: 先输入命令: sudo apt-get install openscene ...
- C++异常处理的深入理解
1,问题: 1,如果在 main 函数中抛出异常会发生什么? 1,不处理,则崩溃: 2,如果异常不处理,最后会传到哪里? 3,下面的代码输出什么? 4,异常的最终处理编程实验: #include &l ...
- 【目录】sql server 进阶篇系列
随笔分类 - sql server 进阶篇系列 sql server 下载安装标记 摘要: SQL Server 2017 的各版本和支持的功能 https://docs.microsoft.com/ ...
- 背包九讲(Orz)
P01: 01背包问题 题目 有\(N\)件物品和一个容量为\(V\)的背包.第\(i\)件物品的费用是\(c[i]\),价值是\(w[i]\).求解将哪些物品装入背包可使这些物品的费用总和不超过背包 ...
- webpack4入门到进阶案例实战课程
愿景:"让编程不在难学,让技术与生活更加有趣" 更多教程请访问xdclass.net 第一章 webpack4前言 第一集 webpack4入门到进阶案例实战课程介绍 简介:讲述w ...
- spring静态资源配置
优雅REST风格的资源URL不希望带 .html 或 .do 等后缀.由于早期的Spring MVC不能很好地处理静态资源,所以在web.xml中配置DispatcherServlet的请求映射,往往 ...
- GenXus学习笔记——Transaction的建立
我们上次聊到 如何正确无误的的创建一个项目KB 那么这次我们就该聊一点实际的东西了(敲黑板( ̄▽ ̄)) 上回书说道我们在创建完自己的KB后 该创建自己的数据库了 首先我们先创建创建一个表 但是创建之 ...
- websocket(python)
1.websocket-server https://github.com/google/pywebsocket git clone https://github.com/google/pywebso ...
- 【机器学习实验】scikit-learn的主要模块和基本使用
[机器学习实验]scikit-learn的主要模块和基本使用 引言 对于一些开始搞机器学习算法有害怕下手的小朋友,该如何快速入门,这让人挺挣扎的.在从事数据科学的人中,最常用的工具就是R和Python ...