汤姆大叔的6道js题目
汤姆大叔的6道javascript编程题题解
看汤姆大叔的博文,其中有篇(猛戳这里)的最后有6道编程题,于是我也试试,大家都可以先试试。

1、找出数字数组中最大的元素(使用Math.max函数)
|
1
2
3
|
var a = [1, 2, 3, 6, 5, 4];var ans = Math.max.apply(null, a);console.log(ans); // 6 |
这题很巧妙地用了apply,如果不是数组,是很多数字求最大值,我们知道可以这样:
|
1
2
|
var ans = Math.max(1, 2, 3, 4, 5, 6); console.log(ans); // 6 |
而apply的第二个参数正是一个数组,都不用进行转换了。
还有一种用eval+toString的实现:
|
1
2
3
|
var a = [1, 2, 3, 6, 5, 4];var ans = eval( 'Math.max(' + a.toString() + ')');console.log(ans); // 6 |
2、转化一个数字数组为function数组(每个function都弹出相应的数字)
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
var a = [1, 2, 3, 4, 5, 6];var len = a.length;for(var i = 0; i < len; i++) { var num = a[i]; (function(num) { var f = function() { console.log(num); }; a[i] = f; })(num);}for(var i = 0; i < len; i++) a[i]();// 1// 2// 3// 4// 5// 6 |
我觉得这跟给n个a标签,弹出相应标签对应的编号是一个类型的题,用闭包保存变量到内存即可。
3、给object数组进行排序(排序条件是每个元素对象的属性个数)
|
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
|
var a = { name: 'hanzichi', age: 10, location: 'china'};var b = { name: 'curry'};var c = { name: 'kobe', sex: 'male'};Object.prototype.getLength = function() { var num = 0; for(var key in this) { if(this.hasOwnProperty(key)) num++; } return num;};var arr = [a, b, c];arr.sort(function(a, b) { return a.getLength() > b.getLength();});console.log(arr); |
这题不难,数组排序,当然是sort,排序条件是对象的属性个数,可以写个函数计算,注意可能要用hasOwnProperty判断下。
4、利用JavaScript打印出Fibonacci数(不使用全局变量)
|
1
2
3
4
5
6
|
(function(a, b) { var c = a + b; console.log(c); if(c > 100) return; arguments.callee(b, c);})(-1, 1); |
这题没看明白,是打出斐波那契数列的前n项么?还是第n项...
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
function fn(n) { var a = []; a[0] = 0, a[1] = 1; for(var i = 2; i < n; i++) a[i] = a[i - 1] + a[i - 2]; for(var i = 0; i < n; i++) console.log(a[i]);}fn(5); // 10表示需要的斐波那契数列个数// 0// 1// 1// 2// 3 |
不使用全局变量,我把它们写在函数里了应该算是局部变量了吧,难道这样就好了?你怎么看?
5、实现如下语法的功能:var a = (5).plus(3).minus(6); //2
|
1
2
3
4
5
6
7
8
9
10
|
Number.prototype.plus = function(a) { return this + a;};Number.prototype.minus = function(a) { return this - a;};var a = (5).plus(3).minus(6);console.log(a); // 2 |
直接在Number对象上加扩展方法即可,传说中这样很不好,but我也想不到更好的办法了...
6、实现如下语法的功能:var a = add(2)(3)(4); //9
|
1
2
3
4
5
6
7
8
9
10
11
|
function add(a) { var temp = function(b) { return add(a + b); } temp.valueOf = temp.toString = function() { return a; }; return temp;}var ans = add(2)(3)(4);console.log(ans); // 9 |
对valueOf和toString的考察,具体可以参考《valueOf和toString》
另看到一种很飘逸的写法(来自Gaubee):
|
1
2
3
4
5
6
7
8
|
function add(num){ num += ~~add; add.num = num; return add;}add.valueOf = add.toString = function(){return add.num};var ans = add(3)(4)(5)(6); // 18alert(ans); |
汤姆大叔的6道js题目的更多相关文章
- 我读汤姆大叔的深入理解js(二)
继续汤姆大叔的js之旅. 揭秘命名函数表达式 函数表达式和函数声明 汤姆大叔在博客中引用ECMA规范:函数声明必须带有标识符,函数表达式可以省略.对于我来说这些概念的东西真是不所适从.还是大叔的实例带 ...
- 我读汤姆大叔的深入理解js(一)
前言 闲来看看javascript,在圆子里发现了汤姆大叔的文章,先是整体瞄了几眼,感觉不错,然后细细研读.记录下自己的学习历程和个人理解.更重要的是作为笔记 高质量JS代码 在看汤姆大叔的这一系列文 ...
- 汤姆大叔的6道javascript编程题题解
看汤姆大叔的博文,其中有篇(猛戳这里)的最后有6道编程题,于是我也试试,大家都可以先试试. 1.找出数字数组中最大的元素(使用Math.max函数) var a = [1, 2, 3, 6, 5, 4 ...
- 汤姆大叔 javascript 系列 第20课 最后的5到javascript题目
博客链接:http://www.cnblogs.com/TomXu/archive/2012/02/10/2342098.html 原题: 大叔注:这些题目也是来自出这5个题目的人,当然如果你能答对4 ...
- 看了汤姆大叔的“你真懂JavaScript吗?”的一些感慨
看了汤姆大叔的“你真懂JavaScript吗?”,里面有5道题目,我都一一作了,然后在chrome的控制台里面运行了一遍,虽然只错了一道,但还是细细读了下答案,在此总结一下,看看是否对大家对这些Jav ...
- TOM大叔的几道Javascript题目与解答
几道JS题目 之前没有深入研究js语言,最近几年前端越来越工程化,需要扎实的js基础,看到博客园上有很多大牛分享JS学习文章,幸运看到tom大叔的blog,抽时间潜心学习了其文章,遇到到其出的几道题目 ...
- 你必须知道ASP.NET知识------关于动态注册httpmodule(对不起汤姆大叔)
一.关于动态注册的问题 很多人看过汤姆大叔的MVC之前的那点事儿系列(6):动态注册HttpModule ,其实汤姆大叔没有发现httpmodule动态注册的根本机制在哪里. 亦即:怎么动态注册?为什 ...
- [转载]深入理解JavaScript系列 --汤姆大叔
深入理解JavaScript系列文章,包括了原创,翻译,转载,整理等各类型文章,如果对你有用,请推荐支持一把,给大叔写作的动力. 深入理解JavaScript系列(1):编写高质量JavaScript ...
- 之前见汤姆大叔 写过一系列的 js 深入理解 呢 很是感觉经典
最近要把这些给翻个遍 加油 js 隐式全局变量 读后感 1:js 没有变量名称是否重复定义的检查,在cshrp里有这样的检查, 没有变量名称重复的检查,这样 当变量名称 重复定义的时候 相同命名的变 ...
随机推荐
- 【转】谁说Vim不是IDE?(二)
谁说Vim不是IDE?(二) 环境配置 “如果你认为Vim只是一个文本编辑器,你就输了”——来自Vim老鸟 Vim以简洁的方式提供了丰富的配置功能,主要配置体系由一个文件和文件夹组成.在一台安装了 ...
- 360浏览器拦截弹窗,window.open方式打不开新页面
window.open虽然在很多时候被广大中小站长用于弹窗广告的展示,所以广受争议,但是在业务需求中还是有很多场景需要用到此功能.然而,大多数浏览器对此都有一定的安全策略进行阻止,为此本文将针对以下浏 ...
- iOS中SQLite知识点总结2
数据库(SQLite) 01-多表查询 格式:select 字段1,字段2,... from 表名1,表名2; 别名:select 别名1.字段1 as 字段别名1,别名2.字段2 as 字段别名2, ...
- 23讲 URL2
这是关于URL路由的小笔记. 为什么用使用URL路由呢? 我的想法是:用户在地址栏可以乱传参数,所以我们必须最出一些防范措施,防止出现用户看到的不友好界面. 例如地址栏的地址为:http://loca ...
- 备忘--简单比较SPSS、RapidMiner、KNIME以及Kettle四款数据分析工具
SPSS.RapidMiner.KNIME以及Kettle四款工具都可以用来进行数据分析,只是彼此有各自的侧重点和有劣势.它们都可以逐步的定义数据分析过程,也同样都可以对数据进行ETL处理.笔者从自己 ...
- [ORACLE]数据库之间复制表
---------------------------------------------------------------------------- -------------ORACLE数据库管 ...
- [MySQL] MySQL的自己主动化安装部署
有过MySQL运维的人应该都清楚,线上的MySQL一般都採用源代码编译,由于这样才干够依据企业的各自须要选择要编译的功能,尽管MySQL的源代码编译挺简单的,可是试想一下,假设你有几百台server同 ...
- Load Balance Tomcat with Nginx and Store Sessions in Redis--reference
An awkward title, but that’s exactly what we’re going to do. For some time, I was looking for a way ...
- Performance Tuning of Spring/Hibernate Applications---reference
http://java.dzone.com/articles/performance-tuning For most typical Spring/Hibernate enterprise appli ...
- JDK1.8 Lambda
1.模拟Model /** * Author:JsonLu * DateTime:16/12/8 14:01 * Email:jsonlu@qq.com * Desc: */ public class ...