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

資訊專欄INFORMATION COLUMN

js面試題

dack / 2910人閱讀

摘要:文章中如果有錯(cuò)誤或者有更好的解法,請(qǐng)多多指出。它類似于數(shù)組,但是成員的值都是唯一的,沒(méi)有重復(fù)的值。

文章中如果有錯(cuò)誤或者有更好的解法,請(qǐng)多多指出。

1.字符串去重

思路:(1)利用對(duì)象key值唯一性

function unique(str){
      var _obj=str.split("");
        var length=str.length;
        var result="";
        var obj={};
        for(var i=0;i

(2)方法2 利用Set (謝謝道友們的分享)
ES6提供了新的數(shù)據(jù)結(jié)構(gòu)Set。它類似于數(shù)組,但是成員的值都是唯一的,沒(méi)有重復(fù)的值。

const unique = str => [...new Set(str.split(""))].join("");

var str="oooooooooooopppppppppppppollllllllllsssssssss"
console.log(unique(str)) // opls

2.查找出在字符串中只出現(xiàn)一次的第一個(gè)字符

舉例-str="pppwrtto" ===> 輸出 w
思路:
1.str去重 [p,w,r,t,o] 同時(shí)將字符出現(xiàn)的次數(shù)記錄下來(lái),組成如下結(jié)構(gòu)
{p:3,w:1,r:1,t:2,o:1}
2.判斷當(dāng)?shù)谝淮蝟bj[key]==1的時(shí)候就返回key值

function firstUnique(str){
    var arr=str.split("");
      var length=arr.length;
      var obj={};
      var num=0;
      for(var i=0;i

3.封裝typeof(重點(diǎn)區(qū)分 引用值---1.數(shù)組,2.對(duì)象,3.包裝類)
思路:1.區(qū)分原始值 引用值 2.原始值 引用值

function type(target){
        //原始值 引用值
        //區(qū)分引用值
        var template={
            "[object Array]":"array",
            "[object Object]":"object",
            "[object Number]":"number-object",
            "[object Boolean]":"boolean-object",
            "[object String]":"string-object"
        }
        if(target===null){
            return "null";
        }else if(typeof(target)=="object"){
            // 數(shù)組
            // 對(duì)象
            // 包裝類 Object.prototype.toString
            var str=Object.prototype.toString.call(target);
            return template[str];
        }else{
            return typeof(target)
        }
    }
    console.log(type("abc"))
    console.log(type(function(){}))
    console.log(type([]))
    console.log(type({}))
    console.log(type(new Number()))
    console.log(type(new Object()))
    console.log(type(new String()))
    console.log(type(new Boolean()))
    console.log(type(new Array()))

4.數(shù)組去重--在原型鏈上進(jìn)行
var arr=[1,1,2,2,"a","a"]
arr.unique-->[1,2,a]
思路:通過(guò)對(duì)象 hash方式

Array.prototype.unique=function(){
        var obj={};
        var result=[];
        var length=this.length;
        for(var i=0;i
function distinct(ary){
    var obj={};
    for(var i=0;i

5.Js實(shí)現(xiàn)方法連續(xù)調(diào)用

var demo={
        smoke:function(){
            console.log("吸煙")
            return this;
        },
        eat:function(){
            console.log("吃飯")
            return this;
        },
        perm:function() {
            console.log("燙頭")
            return this;
        }
    }
    demo.smoke().eat().perm()

6.低耦合寫(xiě)出階乘函數(shù)
--消除緊密耦合的現(xiàn)象,可以像下面這樣使用 arguments.callee(嚴(yán)格模式下callee失效)

function factorial(num){
        if(num<=1){
            return 1;
        }else{
            return num*arguments.callee(num-1)
        }
    }
    console.log(factorial(3))

7.&&與||運(yùn)算符

 var a=1&&2; //&& 如果第一個(gè)表達(dá)式為真,將返回第二個(gè)表達(dá)式值返回
    console.log(a);
    var b=1&&2+2;
    console.log(b);
    var c=0&&2; //&& 如果第一個(gè)表達(dá)式為假,將返回第一個(gè)表達(dá)式值返回
    console.log(c)
    var d=1||2;//|| 第一個(gè)表達(dá)式為真,則直接返回
    console.log(d)
    var e=0||2;//|| 第一個(gè)表達(dá)式為假,則返回第二個(gè)值
    console.log(e)

    2>1&&document.write("hello");
    var data;
    data&&console.log("ni hao")

8.淺拷貝

我們知道引用類型的賦值其實(shí)是改變了變量的指向,那么如果在需要拷貝的對(duì)象中存在某個(gè)屬性的值是引用類型,如數(shù)組或子對(duì)象,那么淺拷貝后的原對(duì)象的屬性獲得的也只是這個(gè)指向。所以如果改變被拷貝對(duì)象的屬性值,那么原對(duì)象的相應(yīng)屬性也會(huì)跟著改變

  function extendCopy(p) {
    var c = {};
    for (var i in p) { 
      c[i] = p[i];
    }
    c.uber = p;
    return c;
  }

9.深拷貝
遞歸

  function deepCopy(p, c) {

    var c = c || {};

    for (var i in p) {

      if (typeof p[i] === "object") {

        c[i] = (p[i].constructor === Array) ? [] : {};

        deepCopy(p[i], c[i]);

      } else {

         c[i] = p[i];

      }
    }

    return c;
  }
  var chinese={
       nation:"中國(guó)",
       minzu:{name1:"漢族",name2:"苗族"}
     }
 var Doctor = deepCopy(Chinese);

數(shù)組&對(duì)象深拷貝

function deepCopy(origin) {
    if (typeof origin != "object") {
        return origin;
    }
    var result;
    if(Object.prototype.toString.call(origin)=== "[object Array]"){
        result=[];
        for(var i in origin){
            result[i]= typeof origin[i]==="object"?deepCopy(origin[i]):origin[i];
        }
    }else{
        result={};
        for (var key in origin) {
            if(origin.hasOwnProperty(key)){
                result[key]= typeof origin[key]==="object"?deepCopy(origin[key]):origin[key];
            }
        }
    }
    return result;
}
    var obj1={
        name:"小黃",
        sister:{name:"花花",age:20},
        grade:[10,20,30,[89,60]]
    };
    var obj2=deepCopy(obj1)

10.函數(shù)預(yù)編譯 GO與AO
最終
GO{

a:100,
demo:function(){},
f:123

}
AO{

e:2,
b:undefined,
a:10

}

 a=100;
    function demo(e){
        function e(){}
        arguments[0]=2;
        console.log(e); //2
        if(a){
            var b=123;
        }
        a=10;
        var a;
        console.log(b);//undefined
        f=123;
        console.log(a);//10
    }
    var a;
    demo(1);
    console.log(a); //100
    console.log(f); //123

11.將 var obj={value0:"1",remark0:"備注1",value1:"2",remark1:"備注2"}; 轉(zhuǎn)換為[{value0:"1",remark0:"備注1"},{value1:"2",remark1:"備注2"}]

    var obj={value0:"1",remark0:"備注1",value1:"2",remark1:"備注2"};
    var count=0;
    var result=[];
    var storage={};
    for(var key in obj){
        count++;
        storage[key]=obj[key]
        if(count%2==0){
            result[count/2-1]=storage;
            storage={};
        }
    }
    console.log(result);

12.輸入一個(gè)整形數(shù)組,數(shù)組中有正數(shù)也有負(fù)數(shù),數(shù)組中連續(xù)的一個(gè)或多個(gè)數(shù)組組成一個(gè)子數(shù)組,每個(gè)子數(shù)組都有一個(gè)和,求所有子數(shù)組和的最大值。

  var s=[20,[1,2,10],[-2,30,[-1,-1,-8]]];
    function max(origin){
        var length=origin.length;
        var array=[]
        for(var i=0;i

13、call原理以及面試題
原理:

Function.prototype.call=function call(context){
   //native code
   //把指定函數(shù)中的this指向context =>也就是fn this改變 -------[把this(call中的this)中的this指向context]
   //把指定函數(shù)執(zhí)行 fn執(zhí)行---- [this執(zhí)行] this()
}
//以下都是讓call方法執(zhí)行
//fn.call(opp)  //call方法中的this 是fn
//fn.__proto__.call();  //call方法中的this是fn.__proto__
//Function.prototype.call(); //call this=>Function.prototype

題目:

function fn1(){
  console.log(1);
}
function fn2(){
  console.log(2)
}
fn1.call(fn2);
//fn1.call :fn1這個(gè)Function的實(shí)例通過(guò)__proto__找到Function.prototype上的call方法,然后讓call方法執(zhí)行(傳遞fn2這個(gè)實(shí)參)  
//執(zhí)行call的時(shí)候,call中的this:fn1,所此處是把fn1執(zhí)行,讓fn1中的this執(zhí)行fn2
fn1.call.call.call(fn2);
//f1.call.call.call 依然是找到原型上的call方法并且讓call執(zhí)行。
//  call3中的this:fn1.call.call[原型上的call]
//  call3中的Context:fn2

// 1.  讓【原型中的call(fn1.call.call)】中的this指向fn2
// 2. 讓[原型上的call(fn1.call.call)]執(zhí)行 
//    -1、第二次執(zhí)行原型上的call,只不過(guò)此時(shí)的call已經(jīng)變?yōu)榱薴n2
//   -2、讓指定函數(shù)fn2中的this指向undefined
//     -3、讓fn2執(zhí)行
Function.prototype.call(fn2);
//  找到原型上的call方法,讓call執(zhí)行
//    call執(zhí)行:
//    this:Function.prototype
//    context:fn2
//
//   把Functon.prototype中的this關(guān)鍵字變?yōu)閒n2
//   讓Function.prototype執(zhí)行
//   ==>無(wú)輸出(匿名空函數(shù)執(zhí)行無(wú)輸出)
Function.prototype.call.call.call(fn2);
// 等價(jià)于 fn1.call.call.call(fn2)

14、阿里面試題目

    function Foo(){
        getName=function(){
            console.log(1)
        };
        return this;
    }
    Foo.getName=function(){
        console.log(2);
    }
    Foo.prototype.getName=function(){
        console.log(3)
    }
    var getName=function(){
        console.log(4)
    }
    function getName(){
        console.log(5)
    }
    Foo.getName() //把Foo作為對(duì)象,找其私有屬性
    getName();// 執(zhí)行全局下的getName
    Foo().getName(); //先將Foo作為普通函數(shù)執(zhí)行,然后在調(diào)取getName
    getName();
    new Foo.getName()//先獲取Foo.getName的值(假設(shè)B),然后在new B()相當(dāng)于創(chuàng)建B的實(shí)例
    new Foo().getName() //先new Foo() 獲取實(shí)例(new Foo()相當(dāng)于將Foo函數(shù)有重新執(zhí)行了一遍,此時(shí)getName->1),把得到的實(shí)例再調(diào)取getName

    new new Foo().getName();//=>var f=new Foo() new f.getName() =>[new (f.getName)]()

15、數(shù)組去重《鏈?zhǔn)綄?xiě)法》

Array.prototype.myDistinct=function myDistinct(){
    var obj={};
    for (var i = 0; i < this.length; i++) {
        var item=this[i];
        if(typeof obj[item]!=="undefined"){
            this[i]=this[this.length-1];
            this.length-1;
            i--;
            continue;
        }
        obj[item]=item;
    }
    obj=null;
    return this;
}
    var ary=[1,2,3,4,1,2,44,3]
    ary.myDistinct();
    ayy.myDistinct.sort();

16.閉包、作用域、變量提升

 var num=1,
        obj={
            num:2,
            fn:(function(num){
                this.num*=2;
                num+=2;
                return function(){
                    this.num*=3;
                    num++;
                    console.log(num)
                }
            })(num)
        }
    var fn=obj.fn;
    fn();
    obj.fn();
    console.log(num,obj.num)

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

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

相關(guān)文章

  • 你不能錯(cuò)過(guò)的前端面試合集

    摘要:收集的一些前端面試題從面試題發(fā)現(xiàn)不足,進(jìn)而查漏補(bǔ)缺,比通過(guò)面試更難得及各大互聯(lián)網(wǎng)公司前端筆試面試題篇及各大互聯(lián)網(wǎng)公司前端筆試面試題篇面試題個(gè)和個(gè)經(jīng)典面試題前端開(kāi)發(fā)面試題如何面試前端工程師很重要個(gè)變態(tài)題解析如何通過(guò)餓了么面試輕 收集的一些前端面試題 從面試題發(fā)現(xiàn)不足,進(jìn)而查漏補(bǔ)缺,比通過(guò)面試更難得 1 BAT及各大互聯(lián)網(wǎng)公司2014前端筆試面試題--Html,Css篇 2 BAT...

    ninefive 評(píng)論0 收藏0
  • 你不能錯(cuò)過(guò)的前端面試合集

    摘要:收集的一些前端面試題從面試題發(fā)現(xiàn)不足,進(jìn)而查漏補(bǔ)缺,比通過(guò)面試更難得及各大互聯(lián)網(wǎng)公司前端筆試面試題篇及各大互聯(lián)網(wǎng)公司前端筆試面試題篇面試題個(gè)和個(gè)經(jīng)典面試題前端開(kāi)發(fā)面試題如何面試前端工程師很重要個(gè)變態(tài)題解析如何通過(guò)餓了么面試輕 收集的一些前端面試題 從面試題發(fā)現(xiàn)不足,進(jìn)而查漏補(bǔ)缺,比通過(guò)面試更難得 1 BAT及各大互聯(lián)網(wǎng)公司2014前端筆試面試題--Html,Css篇 2 BAT...

    darkbaby123 評(píng)論0 收藏0
  • 前端最強(qiáng)面經(jīng)匯總

    摘要:獲取的對(duì)象范圍方法獲取的是最終應(yīng)用在元素上的所有屬性對(duì)象即使沒(méi)有代碼,也會(huì)把默認(rèn)的祖宗八代都顯示出來(lái)而只能獲取元素屬性中的樣式。因此對(duì)于一個(gè)光禿禿的元素,方法返回對(duì)象中屬性值如果有就是據(jù)我測(cè)試不同環(huán)境結(jié)果可能有差異而就是。 花了很長(zhǎng)時(shí)間整理的前端面試資源,喜歡請(qǐng)大家不要吝嗇star~ 別只收藏,點(diǎn)個(gè)贊,點(diǎn)個(gè)star再走哈~ 持續(xù)更新中……,可以關(guān)注下github 項(xiàng)目地址 https:...

    wangjuntytl 評(píng)論0 收藏0
  • 前端開(kāi)發(fā)面試鏈接

    摘要:手冊(cè)網(wǎng)超級(jí)有用的前端基礎(chǔ)技術(shù)面試問(wèn)題收集前端面試題目及答案匯總史上最全前端面試題含答案常見(jiàn)前端面試題及答案經(jīng)典面試題及答案精選總結(jié)前端面試過(guò)程中最容易出現(xiàn)的問(wèn)題前端面試題整理騰訊前端面試經(jīng)驗(yàn)前端基礎(chǔ)面試題部分最新前端面試題攻略前端面試前端入 手冊(cè)網(wǎng):http://www.shouce.ren/post/index 超級(jí)有用的前端基礎(chǔ)技術(shù)面試問(wèn)題收集:http://www.codec...

    h9911 評(píng)論0 收藏0
  • 前端開(kāi)發(fā)面試鏈接

    摘要:手冊(cè)網(wǎng)超級(jí)有用的前端基礎(chǔ)技術(shù)面試問(wèn)題收集前端面試題目及答案匯總史上最全前端面試題含答案常見(jiàn)前端面試題及答案經(jīng)典面試題及答案精選總結(jié)前端面試過(guò)程中最容易出現(xiàn)的問(wèn)題前端面試題整理騰訊前端面試經(jīng)驗(yàn)前端基礎(chǔ)面試題部分最新前端面試題攻略前端面試前端入 手冊(cè)網(wǎng):http://www.shouce.ren/post/index 超級(jí)有用的前端基礎(chǔ)技術(shù)面試問(wèn)題收集:http://www.codec...

    snifes 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<