JavaScript模式读书笔记 第4章 函数
1。JavaScript函数具有两个特点: 函数是第一类对象 函数能够提供作用域
//这是一个函数表达式//它做为一个參数传递给函数 CallMecallMe(function(){//这是命名函数表达式//也被称作匿名函数});//这是命名函数表达式callMe(function me(){//这里是命名函数表达式//而且其名称为me});//还有一个函数表达式var myobject = {say:function(){//这里是函数表达式}};
<script>function writeCode(callBack){console.log("callBanck before.....");callBack();console.log("callBanck after.....");}function callBack(){console.log("callBanck ..........");}writeCode(callBack);</script>//输出结果callBanck before..... test1.html:14callBanck .......... test1.html:21
callBanck after.....
<script>//查找节点var findNodes = function(){var i = 100000,//复杂循环nodes[],//存储本次执行结果found;//零时存储找到的节点while(i){//业务逻辑处理//....found = 1;i -= 1;nodes.push(found);}return nodes;};//对节点处理var hide = function(nodes){var i = 0, max = nodes.length;for(; i < max; i += 1){//复杂业务逻辑处理console.log(nodes[i]);}};//执行函数hide(findNodes());</script>
<script>var findNodes = function(callBack){var i = 10000,nodes = [],dound;//检查回调函数是否为可调用if(typeof callBack != "function"){callBack = false;}while(i){i -= 1;//逻辑处理 。 。 。 。。。。 。//执行回调函数if(callBack){callBack(found);}nodes.push[found];}return nodes;};var hide = function(node){//对node节点进行相应的业务处理};findNodes(hide);</script>
var scareMe = function(){console.log("FIRST!");scareMe = function(){console.log("SECOND!");};};scareMe();scareMe();输出结果:日志: FIRST!
日志: SECOND!
<script>var scareMe = function(){console.log("FIRST!");scareMe = function(){console.log("SECOND!");};};//加入新的属性scareMe.property = "property";//赋值给还有一个不同名称的变量var prank = scareMe;//在一个方法里使用var spooky = {boo: scareMe};prank();// firstprank();//firstconsole.log(prank.property);//propertyspooky.boo();//firstspooky.boo();//firstconsole.log(spooky.boo.property);//property//使用自己定义函数scareMe();//secondscareMe();//secondconsole.log(scareMe.property);//undefined</script>输出结果:FIRST! test5.html:14
property test5.html:332FIRST! test5.html:14
property test5.html:372SECOND! test5.html:17
undefined
(function(){alert("One");}());
例如以下代码就不会创建过多的全局变量。
<script>(function(){var days = ['sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat'],today = new Date(),msg = "Today is " + days[today.getDay()] + "," + today.getDate();alert(msg);}());</script>
(function(who, how){console.log("i'm " + who + ",I'm " + how);}("pengke", "shabi"));
var result = (function(){return 2 +2 ;})();
<script>
function addPerson(conf){ console.log(conf.first);
console.log(conf.second);
console.log(conf);
}
var conf = {first: "abc",
second: "a",
third: "c"}; addPerson(conf); </script>
<script>//定义函数var sayHi = function(who){console.log("Hello " + (who ? "," + who : "") + "!");};sayHi();sayHi('world');sayHi.apply(null, ["world"]);</script>
运行结果Hello ! test10.html:15Hello ,world! test10.html:15Hello ,world!
<script>//curry化的add函数function add(x, y){var oldx = x, oldy = y;if(typeof oldy == "undefined"){return function(newy){console.log(oldx + newy);};}console.log(x + y);}console.log(typeof add(5));//functionadd(3)(4);//7var add2000 = add(2000);add2000(10);//2010</script>
JavaScript模式读书笔记 第4章 函数的更多相关文章
- JavaScript模式读书笔记 文章3章 文字和构造
1.对象字面量 -1.Javascript中所创建的自己定义对象在任务时候都是可变的.能够从一个空对象開始,依据须要添加函数.对象字面量模式能够使我们在创建对象的时候向其加入函数. ...
- C++ primer plus读书笔记——第8章 函数探幽
第8章 函数探幽 1. 对于内联函数,编译器将使用相应的函数代码替换函数调用,程序无需跳到一个位置执行代码,再调回来.因此,内联函数的运行速度比常规函数稍快,但代价是需要占用更多内存. 2. 要使用内 ...
- C++ primer plus读书笔记——第7章 函数——C++的编程模块
第7章 函数--C++的编程模块 1. 函数的返回类型不能是数组,但可以是其他任何一种类型,甚至可以是结构和对象.有趣的是,C++函数不能直接返回数组,但可以将数组作为结构或对象的组成部分来返回. 2 ...
- 【javascript dom读书笔记】 第九章 CSS-DOM
用dom设置样式 element.style.property = value 何时用dom脚本设置样式 作者写到:绝大多数的现代浏览器,虽然对css伪类的支持不是很完整,但是对dom都有良好的支持, ...
- 《C和指针》 读书笔记 -- 第7章 函数
1.当程序调用一个无法见到原型的函数时,编译器便认为该函数返回一个整型值.如果这个值实际上是非整型值时,还得执行类型转换,所以函数原型声明有时很重要. 2.值的类型并不是值的内在本质,而是取决于它被使 ...
- 《C++ Primer Plus 6th》读书笔记 - 第8章 函数探幽
1. 摘录 默认参数指的是当函数调用中省略了实参时自动使用的一个值. 默认参数并非编程方面的重大突破,而只是提供了一种便捷的方式.使用默认参数,可以减少要定义的析构函数.方法以及方法重载的数量. 试图 ...
- 《C++ Primer 4th》读书笔记 第7章-函数
原创文章,转载请注明出处:http://www.cnblogs.com/DayByDay/p/3912413.html
- 《Linux内核分析》读书笔记(四章)
<Linux内核分析>读书笔记(四章) 标签(空格分隔): 20135328陈都 第四章 进程调度 调度程序负责决定将哪个进程投入运行,何时运行以及运行多长时间,进程调度程序可看做在可运行 ...
- SQL Server2012 T-SQL基础教程--读书笔记(1-4章)
SQL Server2012 T-SQL基础教程--读书笔记(1-4章) SqlServer T-SQL 示例数据库:点我 Chapter 01 T-SQL 查询和编程背景 1.3 创建表和定义数据的 ...
随机推荐
- 入门开发工具idea常见问题之选项中没有servlet
1.在maven中如果创建不了servlet,在project Setting旁边的添加一个web选项,就可以创建servlet了. 初次接触这个陌生的工具还是不太好弄.
- Linq学习(零)-错误汇总
问题一: Cannot execute text selection: CS0009 Metadata file 'C:\Users\Kimisme\Documents\LINQPad Plugins ...
- WinForm窗体项目 之 MySchool管理系统终极版
学习WinForm窗体程序也有一段时间了,今天就来尝试着来一个项目热热身~ 在我们通常使用的MySchool管理中,不外乎这几种功能:增.删.改.查.改密码 在过去的C#中确实是挺简单的,但是在学习了 ...
- 史上巨坑: vim的"set foldmethod=syntax"设置竟然是导致ctrl+p(ctrl+n)补全在文件稍大时光标位于中间位置补全效率变慢的元凶!
最近我的vim又让我闹心了. 问题出现在supertab的补全速度上, 有时候按下tab键半天才弹出补全列表, 即便是弹出了列表在列表上下移动也变得的相当缓慢, 这让我的很是蛋疼. 在完全无法接受这个 ...
- Tcl之Lab1
Task 1. Use help 1) What is the default switch for the redirect command? -file help -v redirect # or ...
- CAD从二制流数据中加载图形(com接口VB语言)
主要用到函数说明: _DMxDrawX::ReadBinStream 从二制流数据中加载图形,详细说明如下: 参数 说明 VARIANT varBinArray 二制流数据,是个byte数组 BSTR ...
- vue04 组件化开发 Vue自动化工具
5. 组件化开发 5.1 组件[component] 组件(Component)是自定义封装的功能.在前端开发过程中,经常出现多个网页的功能是重复的,而且很多不同的网站之间,也存在同样的功能. 而在网 ...
- Linux之FTP/TFTP(vsftp、vsftpd) HTTP(httpd、apache) DHCP(dhcpd)
FTP/TFTP(vsftp.vsftpd): FTP是File Transfer Protocol(文件传输协议)而中文简称为"文传协议".用于Internet上的控制文件的双向 ...
- MG loves string
MG loves string Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others ...
- Android音乐、视频类APP常用控件:DraggablePanel(1)
Android音乐.视频类APP常用控件:DraggablePanel(1) Android的音乐视频类APP开发中,常涉及到用户拖曳视频.音乐播放器产生一定交互响应的设计需求,最典型的以You ...