一、统计数组 arr 中值等于 item 的元素出现的次数
return arr.filter(function(a){
return (a==item);
}).length
}
function count(arr,item) {
var res;
return (res = arr.toString().match(new RegExp("//b"+item+"//b","g")))?res.length:0;
}
function count(arr,item) {
var count = 0;
arr.map(function(a) {
if(a === item) {
count++;
}
});
return count;
}
二、为数组 arr 中的每个元素求二次方。不要直接修改数组 arr,结果返回新的数组
//声明一个新的数组存放结果
var a = [];
arr.forEach(function(e){
//将arr中的每一个元素求平方后,加入到a数组中
a.push(e*e);
});
return a;
}
function square(arr) {
//复制一个arr数组
var newarr = arr.slice(0);
for (var i=0;i<newarr.length;i++){
newarr[i]= newarr[i]* newarr[i];
}
return newarr;
}
function square(arr) {
return arr.map(function(item){
return Math.pow(item,2);
})
}
三、将数组 arr 中的元素作为调用函数 fn 的参数
return function(para1,para2){
return para1.apply(this,para2);
}(fn,arr);
}
四、完成函数 createModule,调用之后满足如下要求:
1、返回一个对象
2、对象的 greeting
属性值等于 str1,name
属性值等于 str2
3、对象存在一个 sayIt
方法,该方法返回的字符串为 greeting
属性值 + ‘,‘ +name属性值
//使用构造函数法
function createModule(str1,str2) {
function Obj(){
this.greeting = str1;
this.name = str2;
this.sayIt = function(){
return this.greeting + ',' + this.name;
};
}
return new Obj();
}
//构造函数与原型组合
function createModule(str1,str2) {
function CreateMod(){
this.greeting = str1;
this.name = str2;
}
CreateMod.prototype.sayIt = function(){
return this.greeting + ',' + this.name;
}
return new CreateMod();
}
五、已知 fn 为一个预定义函数,实现函数 curryIt,调用之后满足如下条件:
1、返回一个函数 a,a 的 length 属性值为1(即显式声明 a 接收一个参数)
2、调用 a 之后,返回一个函数 b,b 的 length 属性值为 1
3、调用 b之后,返回一个函数 c,c 的 length 属性值为 1
输入例子:
function curryIt(fn) {
return function a(xa){
return function b(xb){
return function c(xc){
return fn.call(this,xa,xb,xc);
};
};
};
}
六、数组中输出元素位置
return arr.indexOf(item);
}
七、数组求和
八、删除给定元素
var newA=arr.slice(0);
for(var i=newA.indexOf(item);i>-1;i=newA.indexOf(item)){
newA.splice(i,1);
}
return newA;
}
总结
Javascript中常见的逻辑题就总结到这了,不知道大家都学会了吗?本文的内容对大家的学习或者工作还是有一定帮助的,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持。