[JavaScript] new Function 과 with

1318 단어
(1) with 의 역할:
식별 자의 검색 우선 순 위 를 바 꾸 고 with 가 지정 한 대상 의 속성 에서 우선 찾 습 니 다.
예: 단독 식별 자
var a=1;
varobj={
    a:2
};

with(obj){
    console.log(a);//2
}

예: 직렬 속성
var a={
    v:1
};
varobj={
    a:{
        v:2
    }
};

with(obj){
    console.log(a.v);    //2
}

(2) new Function 의 역할:
문자열 을 사용 하여 가장 바깥쪽 품사 역할 영역 에 함 수 를 만 듭 니 다.
예:
var a=1;
function f(){
    var a=2;
    var g=new Function('alert(a);');    //1
    g();
}
f();

예:
var a=1;
function f(){
    var a=2;
    var g=new Function('function h(){alert(a);};h();');    //1
    g();
}
f();

(3)new Function+with
varfn=new Function('obj','with(obj){return prop.value;}');
var data={
    prop:{
        value:1
    }
};
fn(data);    //1
data['propName'] 에 비해 new Function + withdata 의 직렬 속성 을 직접 방문 할 수 있다.따라서 자 바스 크 립 트 템 플 릿 엔진 에 자주 사 용 됩 니 다.
functionevalPropChain(data,propChainStr){
    return new Function('obj','with(obj){return '+propChainStr+';}')(data);
}
var data={
    prop:{
        value:1
    }
};
evalPropChain(data,'prop.value');    //1

좋은 웹페이지 즐겨찾기