成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

javascript的有趣邏輯片段

xingqiba / 2904人閱讀

摘要:準(zhǔn)備面試的刷題過程中,遇到了一些題,比較有意思,輕巧??杀硎救缦陆o出參數(shù)表示當(dāng)前字符串中從下標(biāo)為的字符開始的長度為的一個子串。反反拼接新的字符串結(jié)合,返回二維數(shù)組中每個一維數(shù)組的最大值用實(shí)現(xiàn)一個數(shù)組合并的方法要求去重。

準(zhǔn)備面試的刷題過程中,遇到了一些題,比較有意思,輕巧。
加強(qiáng)運(yùn)用一下js原生語法,多解。

題目來源:https://github.com/rmurphey/j...
A test-driven approach to assessing JS skills

統(tǒng)計(jì)數(shù)組 arr 中值等于 item 的元素出現(xiàn)的次數(shù)

function count(arr, item) {
     var count = 0;
     arr.forEach(function(e){
         //e為arr中的每一個元素,與item相等則count+1
         e == item ? count++ : 0;
     });
     return count;
 }

function count(arr, item) {
    return arr.filter(function(a){
        return (a==item);
    }).length
}

function count(arr, item) {
    var res;
    return (res = arr.toString().match(new RegExp(""+item+"","g")))?res.length:0;
}

function count(arr, item) {
            var count = 0;
            arr.map(function(a) {
                if(a === item) {
                    count++;
                }
            });
            return count;
        }
        

為數(shù)組 arr 中的每個元素求二次方。不要直接修改數(shù)組 arr,結(jié)果返回新的數(shù)組

function square(arr) {
    return arr.map(function(item,index,array){
        return item*item;
    })
}

function square(arr) {
   //聲明一個新的數(shù)組存放結(jié)果
     var a = [];
     arr.forEach(function(e){
         //將arr中的每一個元素求平方后,加入到a數(shù)組中
         a.push(e*e);
     });
     return a;
 }

function square(arr) {
//復(fù)制一個arr數(shù)組
    var newarr = arr.slice(0);
    for (var i=0;i

將數(shù)組 arr 中的元素作為調(diào)用函數(shù) fn 的參數(shù)

function argsAsArray(fn, arr) {
  return fn.apply(this, arr);
 }

function argsAsArray(fn, arr) {
    return function(para1,para2){ 
        return  para1.apply(this,para2);
    }(fn,arr);
}

完成函數(shù) createModule,調(diào)用之后滿足如下要求:

1、返回一個對象
2、對象的 greeting 屬性值等于 str1,name 屬性值等于 str2
3、對象存在一個 sayIt 方法,該方法返回的字符串為 greeting屬性值 + ", " +name屬性值

function createModule(str1, str2) {
     var obj = {
         greeting : str1,
         name     : str2,
         sayIt    : function(){
             //兩個屬性前面都需要加上this
             return this.greeting+", "+this.name;
         }
     };
     return obj;
 }

//使用構(gòu)造函數(shù)法
function createModule(str1, str2) {
    function Obj(){
        this.greeting = str1;
        this.name = str2;
        this.sayIt = function(){
            return this.greeting + ", " + this.name;
        };
    }
    return new Obj();
}

//構(gòu)造函數(shù)與原型組合
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 為一個預(yù)定義函數(shù),實(shí)現(xiàn)函數(shù) curryIt,調(diào)用之后滿足如下條件:

1、返回一個函數(shù) a,a 的 length 屬性值為1(即顯式聲明 a 接收一個參數(shù))
2、調(diào)用 a 之后,返回一個函數(shù) b, b 的 length 屬性值為 1
3、調(diào)用 b之后,返回一個函數(shù) c, c 的 length 屬性值為 1
4、調(diào)用 c 之后,返回的結(jié)果與調(diào)用 fn 的返回值一致
5、fn的參數(shù)依次為函數(shù) a, b, c 的調(diào)用參數(shù)

輸入例子:

var fn = function (a, b, c) {return a + b + c}; curryIt(fn)(1)(2)(3);
function curryIt(fn) {
     //獲取fn參數(shù)的數(shù)量
     var n = fn.length;
     //聲明一個數(shù)組args
     var args = [];
     //返回一個匿名函數(shù)
     return function(arg){
         //將curryIt后面括號中的參數(shù)放入數(shù)組
         args.push(arg);
         //如果args中的參數(shù)個數(shù)小于fn函數(shù)的參數(shù)個數(shù),
         //則執(zhí)行arguments.callee(其作用是引用當(dāng)前正在執(zhí)行的函數(shù),這里是返回的當(dāng)前匿名函數(shù))。
         //否則,返回fn的調(diào)用結(jié)果
         if(args.length < n){
            return arguments.callee;
         }else return fn.apply("",args);
     }
 }

function curryIt(fn) {
    return function a(xa){
        return function b(xb){
            return function c(xc){
                return fn.call(this,xa,xb,xc);
            };
        };
    };
}

數(shù)組中輸出元素位置

function indexof(arr,item){
    for(var i = 0,len = arr.length;i

數(shù)組求和

function sum(arr) {
    return eval(arr.join("+"));
};

刪除給定元素

   function remove(arr, item) {
        for(var i=0, m=arr.length, res=[]; i-1;i=newA.indexOf(item)){
        newA.splice(i,1);
    }
    return newA;
}

將函數(shù)放入數(shù)組,參數(shù)放入函數(shù),調(diào)用數(shù)組里面的函數(shù),返回函數(shù)執(zhí)行的結(jié)果。

function makeclosures(arr,fn){
    var funcs = [];
    for(var i = 0;i

將函數(shù)a暫時保存在一個內(nèi)建函數(shù)result中,返回這個result函數(shù),再執(zhí)行.(有閉包,call/apply)

partialUsingArguments(test,a,b)(c,d);//用法

function partialUsingArguments(fn){
    var args1  = Array.prototype.slice.call(arguments,1);
    var result = function(){
        var args2 = Array.prototype.slice.call(arguments,0);
        var args = args1.concat(args2);
        return fn.apply(null,args);
    }
    return result;
}

判斷字符串是否連續(xù)重復(fù)(若是,則返回true)

function containRepeatingLetter(str){
    var re = /[a-zA-Z]/;
    for(var i = 0,len = str.length;i

如下的結(jié)果是?

var m= 1, 
j = k = 0; 
function add(n) { 
    return n = n+1; 
  } 
y = add(m);   //4
function add(n) { 
    return n = n + 3; 
} 
z = add(m);   //4


所有聲明的函數(shù)都會被提前。所以function add(){}定義的函數(shù)會優(yōu)先解析,而不是順序解析;因此整個過程中,首先依次解析兩個add function,由于同名,所以后者會覆蓋前者;然后,順序解析其余的JS代碼,y = add(m);語句和z = add(m); 語句調(diào)用的都是第二個add function,因此返回的都是4.

如下的結(jié)果是?

 (function() {
          var a = b = 5;
      })();   
    console.log(b);  //5
    console.log(a);   //a is not defined
    
    

vara=b=5;其中var a表示a為當(dāng)前作用域的全局變量,b=5并沒有定義為當(dāng)前作用域的全局變量,它會申明提前在全局作用域中。
可表示如下:

var b=5;
(function() {
      var a = b ;
  })();        
  console.log(b);  //5
  console.log(a);   //a is not defined      
  
  

給出參數(shù) str,start,end 表示當(dāng)前字符串中從下標(biāo)為 start 的字符開始的長度為 end
的一個子串。你要將這個子串左右翻轉(zhuǎn)后插在這個子串原來位置的正后方,求最后得到的字符串是什么。

  
 function reverseString(str,start,end){
     var slice = str.slice(start,end);
     var sliceReverse = slice.split("").reverse().join(""); //string -> array ->反array -> 反string
     var reverseString = str.slice(0,start+end)+sliceReverse+str.slice(start+end); //拼接新的字符串
     return reverseString;
}     

apply,bind(es5)結(jié)合,返回二維數(shù)組中每個一維數(shù)組的最大值

function largestOfFour(arr) {
  return arr.map(Function.apply.bind(Math.max, null));
}
largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]]);

用JS實(shí)現(xiàn)一個數(shù)組合并的方法(要求去重)。

var arr1 = ["a"];
var arr2 = ["b", "c"];
var arr3 = ["c", ["d"], "e", undefined, null];

var concat = (function(){
  // concat arr1 and arr2 without duplication.
  var concat_ = function(arr1, arr2) {
    for (var i=arr2.length-1;i>=0;i--) {
      arr1.indexOf(arr2[i]) === -1 ? arr1.push(arr2[i]) : 0;
    }
  };
  // concat arbitrary arrays.
  // Instead of alter supplied arrays, return a new one.
  return function(arr) {
    var result = arr.slice();
    for (var i=arguments.length-1;i>=1;i--) {
      concat_(result, arguments[i]);
    }
    return result;
  };
}());

為字符串實(shí)現(xiàn)一個render方法,實(shí)現(xiàn)下面的變量替換功能

var greeting = "my name is $(name),age $(age)";
var result = greeting.render({name:"XiaoMing",age:11});
console.log(result); // my name is XiaoMing,age 11

answer:

 String.prototype.render = function(option){
        var s = this,
                reg;
        Object.keys(option).forEach(function(k){
            reg = new RegExp("$("+k+")","g");
            s = s.replace(reg,option[k])
        });
        return s
    };

    var greeting = "my name is $(name),age $(age)";
    var result = greeting.render({name:"XiaoMing",age:11});
    console.log(result); // my name is XiaoMing,age 11

取字符串中間的字符,奇數(shù)取1,偶數(shù)取2

function getMiddle(str){
   return str.substr(Math.ceil(str.length/2-1),str.length % 2 == 0 ? 2: 1)
 }
var p1 = getMiddle("test"); //es
    var p2 = getMiddle("testing"); //t
    var p3 = getMiddle("middle"); //dd
    var p4 = getMiddle("A"); //A

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/80362.html

相關(guān)文章

  • 翻譯_20行代碼創(chuàng)造JavaScript模板引擎(一)

    摘要:翻譯行代碼創(chuàng)造模板引擎一想看博客原文鏈接,請點(diǎn)擊下方一個非常好用的學(xué)習(xí)正則表達(dá)的網(wǎng)站正則表達(dá)式圖文解說網(wǎng)站譯文事情的起因,我想編寫一個邏輯簡單的模板引擎,它可以很好滿足我現(xiàn)在的需求。,表示全局匹配。 翻譯_20行代碼創(chuàng)造JavaScript模板引擎(一) 想看博客原文鏈接,請點(diǎn)擊下方 JavaScript template engine in just 20 lines 一個非常好用...

    hiyang 評論0 收藏0
  • [譯] 只有 20 行 JavaScript 模板引擎

    摘要:原文鏈接譯者吐槽只收藏不點(diǎn)贊都是耍流氓前言我仍舊在為我的預(yù)處理器進(jìn)行開發(fā)工作。它原本是一個預(yù)處理器,但之后它擴(kuò)展成為了預(yù)處理器,很快它將支持到的轉(zhuǎn)換。 原文鏈接:JavaScript template engine in just 20 lines (譯者吐槽:只收藏不點(diǎn)贊都是耍流氓) 前言 我仍舊在為我的JS預(yù)處理器AbsurdJS進(jìn)行開發(fā)工作。它原本是一個CSS預(yù)處理器,但之后它擴(kuò)...

    leon 評論0 收藏0
  • javascript知識點(diǎn)

    摘要:模塊化是隨著前端技術(shù)的發(fā)展,前端代碼爆炸式增長后,工程化所采取的必然措施。目前模塊化的思想分為和。特別指出,事件不等同于異步,回調(diào)也不等同于異步。將會討論安全的類型檢測惰性載入函數(shù)凍結(jié)對象定時器等話題。 Vue.js 前后端同構(gòu)方案之準(zhǔn)備篇——代碼優(yōu)化 目前 Vue.js 的火爆不亞于當(dāng)初的 React,本人對寫代碼有潔癖,代碼也是藝術(shù)。此篇是準(zhǔn)備篇,工欲善其事,必先利其器。我們先在代...

    Karrdy 評論0 收藏0
  • 【翻譯】Web渲染概述

    摘要:由我所在的團(tuán)隊(duì)共同翻譯完成,并發(fā)布在前端技術(shù)公眾號方凳雅集上,轉(zhuǎn)載于此。在移動端,客戶端渲染很難獲得并保持一個較快的渲染速度。使用技術(shù)進(jìn)行服務(wù)端渲染的主要問題在于它會對可交互時間有明顯的負(fù)面影響,盡管它縮短了首次繪制時間 本文簡單介紹了web應(yīng)用各種渲染方案,其中包括客戶端渲染、服務(wù)器端渲染等各種渲染方案。文章翻譯自:https://developers.google.com...。由...

    RobinQu 評論0 收藏0
  • 【翻譯】Web渲染概述

    摘要:由我所在的團(tuán)隊(duì)共同翻譯完成,并發(fā)布在前端技術(shù)公眾號方凳雅集上,轉(zhuǎn)載于此。在移動端,客戶端渲染很難獲得并保持一個較快的渲染速度。使用技術(shù)進(jìn)行服務(wù)端渲染的主要問題在于它會對可交互時間有明顯的負(fù)面影響,盡管它縮短了首次繪制時間 本文簡單介紹了web應(yīng)用各種渲染方案,其中包括客戶端渲染、服務(wù)器端渲染等各種渲染方案。文章翻譯自:https://developers.google.com...。由...

    NervosNetwork 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<