21、题目描述
将数组 arr 中的元素作为调用函数 fn 的参数
代码:
输入例子:
argsAsArray(function (greeting, name, punctuation) {return greeting + ', ' + name + (punctuation || '!');}, ['Hello', 'Ellie', '!'])
输出例子:
Hello, Ellie!
function argsAsArray(fn, arr) {
return fn.apply(this,arr);
}
22、题目描述
将函数 fn 的执行上下文改为 obj 对象
代码:
输入例子:
speak(function () {return this.greeting + ', ' + this.name + '!!!';}, {greeting: 'Hello', name: 'Rebecca'})
输出例子:
Hello, Rebecca!!!
function speak(fn, obj) {
return fn.apply(obj,arguments);
}
23、题目描述
实现函数 functionFunction,调用之后满足如下条件:
1、返回值为一个函数 f
2、调用返回的函数 f,返回值为按照调用顺序的参数拼接,拼接字符为英文逗号加一个空格,即 ', '
3、所有函数的参数数量为 1,且均为 String 类型
代码:
1、返回值为一个函数 f
2、调用返回的函数 f,返回值为按照调用顺序的参数拼接,拼接字符为英文逗号加一个空格,即 ', '
3、所有函数的参数数量为 1,且均为 String 类型
输入例子:
functionFunction('Hello')('world')
输出例子:
Hello, world
function functionFunction(str) {
var f=function(str2){
if(typeof(str)=="string" && typeof(str2)=="string")
return str+', '+str2;//2、返回值
else return false;
};
return f;//1、返回函数f
}
24、题目描述
实现函数 makeClosures,调用之后满足如下条件:
1、返回一个函数数组 result,长度与 arr 相同
2、运行 result 中第 i 个函数,即 result[i](),结果与 fn(arr[i]) 相同
代码:
1、返回一个函数数组 result,长度与 arr 相同
2、运行 result 中第 i 个函数,即 result[i](),结果与 fn(arr[i]) 相同
输入例子:
var arr = [1, 2, 3]; var square = function (x) { return x * x; }; var funcs = makeClosures(arr, square); funcs[1]();
输出例子:
4
function makeClosures(arr, fn) {
var result = [];//声明要返回的数组result
for(var i=0;i<arr.length;i++){//数组result的长度与arr的长度相同
result[i]=fun(i);//数组的值为函数fun的返回值
}
function fun(i){//定义函数fun
return function(){//函数fun返回给数组result的值为一个匿名函数
return fn(arr[i]);//这个匿名函数的返回值为fn(arr[i])
}
}
return result;
}
25、题目描述
已知函数 fn 执行需要 3 个参数。请实现函数 partial,调用之后满足如下条件:
1、返回一个函数 result,该函数接受一个参数
2、执行 result(str3) ,返回的结果与 fn(str1, str2, str3) 一致
代码:
1、返回一个函数 result,该函数接受一个参数
2、执行 result(str3) ,返回的结果与 fn(str1, str2, str3) 一致
输入例子:
var sayIt = function(greeting, name, punctuation) { return greeting + ', ' + name + (punctuation || '!'); }; partial(sayIt, 'Hello', 'Ellie')('!!!');
输出例子:
Hello, Ellie!!!
function partial(fn, str1, str2) {
function result(str3){
return fn(str1,str2,str3);
}
return result;
}
26、题目描述
函数 useArguments 可以接收 1 个及以上的参数。请实现函数 useArguments,返回所有调用参数相加后的结果。本题的测试参数全部为 Number 类型,不需考虑参数转换。
代码:
输入例子:
useArguments(1, 2, 3, 4)
输出例子:
10
function useArguments() {
var sum=0;
for(var i=0;i<arguments.length;i++)
sum+=arguments[i];
return sum;
}
27、题目描述
实现函数 callIt,调用之后满足如下条件
1、返回的结果为调用 fn 之后的结果
2、fn 的调用参数为 callIt 的第一个参数之后的全部参数
代码:
1、返回的结果为调用 fn 之后的结果
2、fn 的调用参数为 callIt 的第一个参数之后的全部参数
输入例子:
var a = 1; var b = 2; var test = function (first, second) { return first === a && second === b;}; callIt(test, a, b);
输出例子:
true
function callIt(fn) {
var args=[];
for(var i=1;i<arguments.length;i++)
args.push(arguments[i]);
var result=fn.apply(null,args);
return result;
}
或者
function callIt(fn) {
return fn.apply(null,Array.prototype.slice.call(arguments,1));
}
28、题目描述
实现函数 partialUsingArguments,调用之后满足如下条件:
1、返回一个函数 result
2、调用 result 之后,返回的结果与调用函数 fn 的结果一致
3、fn 的调用参数为 partialUsingArguments 的第一个参数之后的全部参数以及 result 的调用参数
代码:
1、返回一个函数 result
2、调用 result 之后,返回的结果与调用函数 fn 的结果一致
3、fn 的调用参数为 partialUsingArguments 的第一个参数之后的全部参数以及 result 的调用参数
输入例子:
var a = 1; var b = 2; var c = 3; var d = 4;var test = function (first, second, third, forth) {return first + second + third + forth;};partialUsingArguments(test, a, b)(c, d);
输出例子:
10
function partialUsingArguments(fn) {
//获取 partialUsingArguments 的第一个参数之后的全部参数
var args1=Array.prototype.slice.call(arguments,1);
//定义result
var result=function(){
//获取 result的调用参数
var args2=Array.prototype.slice.call(arguments,0);
//将参数整合到一个数组中
var args=args1.concat(args2)
return fn.apply(null,args);
}
//返回result
return result;
}
29、题目描述
已知 fn 为一个预定义函数,实现函数 curryIt,调用之后满足如下条件:
1、返回一个函数 a,a 的 length 属性值为 1(即显式声明 a 接收一个参数)
2、调用 a 之后,返回一个函数 b, b 的 length 属性值为 1
3、调用 b 之后,返回一个函数 c, c 的 length 属性值为 1
4、调用 c 之后,返回的结果与调用 fn 的返回值一致
5、fn 的参数依次为函数 a, b, c 的调用参数
代码:
1、返回一个函数 a,a 的 length 属性值为 1(即显式声明 a 接收一个参数)
2、调用 a 之后,返回一个函数 b, b 的 length 属性值为 1
3、调用 b 之后,返回一个函数 c, c 的 length 属性值为 1
4、调用 c 之后,返回的结果与调用 fn 的返回值一致
5、fn 的参数依次为函数 a, b, c 的调用参数
输入例子:
var fn = function (a, b, c) {return a + b + c}; curryIt(fn)(1)(2)(3);
输出例子:
6
function curryIt(fn) {
return a=function(ra){
return b=function(rb){
return c=function(rc){
return fn(ra,rb,rc);
}
}
}
}
30、题目描述
返回参数 a 和 b 的逻辑或运算结果
代码:
输入例子:
or(false, true)
输出例子:
true
function or(a, b) {
return a||b;
}
31、题目描述
返回参数 a 和 b 的逻辑且运算结果
代码:
输入例子:
and(false, true)
输出例子:
false
function and(a, b) {
return a&&b;
}
32、题目描述
完成函数 createModule,调用之后满足如下要求:
1、返回一个对象
2、对象的 greeting 属性值等于 str1, name 属性值等于 str2
3、对象存在一个 sayIt 方法,该方法返回的字符串为 greeting属性值 + ', ' + name属性值
代码:
1、返回一个对象
2、对象的 greeting 属性值等于 str1, name 属性值等于 str2
3、对象存在一个 sayIt 方法,该方法返回的字符串为 greeting属性值 + ', ' + name属性值
function createModule(str1, str2) {
var obj={
greeting:str1,
name:str2,
sayIt:function(){
return this.greeting+', '+this.name;
}
};
return obj;
}
33、题目描述
获取数字 num 二进制形式第 bit 位的值。注意:
1、bit 从 1 开始
2、返回 0 或 1
3、举例:2 的二进制为 10,第 1 位为 0,第 2 位为 1
代码:
1、bit 从 1 开始
2、返回 0 或 1
3、举例:2 的二进制为 10,第 1 位为 0,第 2 位为 1
输入例子:
valueAtBit(128, 8)
输出例子:
1
function valueAtBit(num, bit) {
var newnum=num.toString(2);
return newnum[newnum.length-bit];
}
34、题目描述
给定二进制字符串,将其换算成对应的十进制数字
代码:
输入例子:
base10('11000000')
输出例子:
192
function base10(str) {
return parseInt(str,2);
}
35、题目描述
将给定数字转换成二进制字符串。如果字符串长度不足 8 位,则在前面补 0 到满8位。
代码:
输入例子:
convertToBinary(65)
输出例子:
01000001
function convertToBinary(num) {
var newnum=num.toString(2);
var newlength=newnum.length;
if(newnum.length<8){
for(var i=0;i<8-newlength;i++)
newnum="0"+newnum;
}
return newnum;
}
36、题目描述
求 a 和 b 相乘的值,a 和 b 可能是小数,需要注意结果的精度问题
代码:
输入例子:
multiply(3, 0.0001)
输出例子:
0.0003
function multiply(a, b) {
return a*b;
}
37、题目描述
将函数 fn 的执行上下文改为 obj,返回 fn 执行后的值
代码:
输入例子:
alterContext(function() {return this.greeting + ', ' + this.name + '!'; }, {name: 'Rebecca', greeting: 'Yo' })
输出例子:
Yo, Rebecca!
function alterContext(fn, obj) {
return fn.apply(obj);
}
或者:
function alterContext(fn, obj) {
return fn.call(obj,obj);
}
38、题目描述
给定一个构造函数 constructor,请完成 alterObjects 方法,将 constructor 的所有实例的 greeting 属性指向给定的 greeting 变量。
代码:
输入例子:
var C = function(name) {this.name = name; return this;}; var obj1 = new C('Rebecca'); alterObjects(C, 'What\'s up'); obj1.greeting;
输出例子:
What's up
function alterObjects(constructor, greeting) {
constructor.prototype.greeting=greeting;
return constructor.greeting;
}
39、题目描述
找出对象 obj 不在原型链上的属性(注意这题测试例子的冒号后面也有一个空格~)
1、返回数组,格式为 key: value
2、结果数组不要求顺序
代码:
1、返回数组,格式为 key: value
2、结果数组不要求顺序
输入例子:
var C = function() {this.foo = 'bar'; this.baz = 'bim';}; C.prototype.bop = 'bip'; iterate(new C());
输出例子:
["foo: bar", "baz: bim"]
function iterate(obj) {
var arr=[];
for(var key in obj){
if(obj.hasOwnProperty(key))//hasOwnProperty用于检验obj的属性key是否是自有的(而不是原型链的)
arr.push(key+": "+obj[key]);
}
return arr;
}
40、题目描述
给定字符串 str,检查其是否包含数字,包含返回 true,否则返回 false
代码:
输入例子:
containsNumber('abc123')
输出例子:
true
function containsNumber(str) {
var reg=/\d/;
return reg.test(str);
}
41、题目描述
给定字符串 str,检查其是否包含连续重复的字母(a-zA-Z),包含返回 true,否则返回 false
代码:
输入例子:
containsRepeatingLetter('rattler')
输出例子:
true
function containsRepeatingLetter(str) {
var reg=/([a-zA-Z])\1/; //\1是对第一个括号中的内容的引用
return reg.test(str);
}
42、题目描述
给定字符串 str,检查其是否以元音字母结尾
1、元音字母包括 a,e,i,o,u,以及对应的大写
2、包含返回 true,否则返回 false
代码:
1、元音字母包括 a,e,i,o,u,以及对应的大写
2、包含返回 true,否则返回 false
输入例子:
endsWithVowel('gorilla')
输出例子:
true
function endsWithVowel(str) {
var reg=/[a,e,i,o,u]$/i; // $表示匹配结尾,/i表示忽略大小写
return reg.test(str);
}
43、题目描述
给定字符串 str,检查其是否包含连续3个都是数字
1、如果包含,返回最先出现的 3 个数字的字符串
2、如果不包含,返回 false
代码:
1、如果包含,返回最先出现的 3 个数字的字符串
2、如果不包含,返回 false
输入例子:
captureThreeNumbers('9876543')
输出例子:
987
function captureThreeNumbers(str) {
var reg=/\d{3}/;
var matcher=str.match(reg);
if(matcher)
return matcher[0];
else return false;
}
44、题目描述
给定字符串 str,检查其是否符合如下格式
1、XXX-XXX-XXXX
2、其中 X 为 Number 类型
代码:
1、XXX-XXX-XXXX
2、其中 X 为 Number 类型
输入例子:
matchesPattern('800-555-1212')
输出例子:
true
function matchesPattern(str) {
var reg=/^\d{3}-\d{3}-\d{4}$/; //注意开头要加^结尾要加$
return reg.test(str);
}
45、题目描述
给定字符串 str,检查其是否符合美元书写格式
1、以 $ 开始
2、整数部分,从个位起,满 3 个数字用 , 分隔
3、如果为小数,则小数部分长度为 2
4、正确的格式如:$1,023,032.03 或者 $2.03,错误的格式如:$3,432,12.12 或者 $34,344.3
代码:
1、以 $ 开始
2、整数部分,从个位起,满 3 个数字用 , 分隔
3、如果为小数,则小数部分长度为 2
4、正确的格式如:$1,023,032.03 或者 $2.03,错误的格式如:$3,432,12.12 或者 $34,344.3
输入例子:
isUSD('$20,933,209.93')
输出例子:
true
<del>function isUSD(str) {
var reg=/^\$([1-9]\d{0,3})(,\d{3})*(\.\d{2})?$/;
/*
1、以 $ 开始: ^$
2、$之后的第一组数字可能是0,1,2,3位: [1-9]\d{0~3}
3、第二组开始之后的数字每组都是一个,加上三个数字:(,\d{3})* //*表示可匹配0~n组
4、如果有小数部分,格式为 .加上两个数字(注意对.进行转义;并且小数为结尾部分):(\.\d{2})?$
*/
return reg.test(str);
}</del>
感谢@
qq_19157005 的提示,如有错误,欢迎指正探讨~,修改如下:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<script>
function isUSD(str) {
var reg=/^\$(([1-9]\d{0,2}|(0)))(,\d{3})*(\.\d{2})?$/;
/*
1、以 $ 开始: ^$
2、如果是小于1的小数,则以0开头(允许0.00);如果大于1,则以1~9开头,后面匹配0~2位的0~9的数字
3、第二组开始之后的数字每组都是一个,加上三个数字:(,\d{3})* //*表示可匹配0~n组
4、如果有小数部分,格式为 .加上两个数字(注意对.进行转义;并且小数为结尾部分):(\.\d{2})?$ (?是非贪婪模式,表示匹配0或1次)
*/
return reg.test(str);
}
console.log(isUSD("$1,023,032.03"));
console.log(isUSD("$2.03"));
console.log(isUSD("$100,000"));
console.log(isUSD("$111.22"));
console.log(isUSD("$0.03"));
console.log(isUSD("$0.03"));
console.log(isUSD("$1,000.03"));
console.log(isUSD("$00,00"));
console.log(isUSD("$34,344.3"));
console.log(isUSD("$3,432,12.12"));
console.log(isUSD("$1000.03"));
</script>
</body>
</html>