>웹 프론트엔드 >JS 튜토리얼 >JS의 바인딩()에 대한 간략한 토론

JS의 바인딩()에 대한 간략한 토론

autoload
autoload원래의
2021-04-06 15:09:176305검색

JS의 바인딩()에 대한 간략한 토론

bind()Function 개체의 내장 메서드입니다. 첫 번째 매개 변수는 호출 메서드에서 this를 변경하는 데 사용됩니다. .>을 가리킨다. bind는 나중에 호출할 수 있도록 새 함수를 반환한다는 점에 유의해야 합니다. bind()Function对象内建的方法,它们的第一个参数都是用来更改调用方法中this的指向。需要注意的是bind 是返回新的函数,以便稍后调用。

1.语法:

function.bind(thisArg[,arg1[,arg2[, ...]]])
  •     thisArg:调用绑定函数时作为 this 参数传递给目标函数的值。 如果使用new运算符构造绑定函数,则忽略该值。当使用 bind 在 setTimeout 中创建一个函数(作为回调提供)时,作为 thisArg 传递的任何原始值都将转换为 object。如果 bind 函数的参数列表为空,或者thisArgnullundefined,执行作用域的 this 将被视为新函数的 thisArg

  •     arg1, arg2, ...:当目标函数被调用时,被预置入绑定函数的参数列表中的参数。

  •     返回值:返回一个原函数的拷贝,并拥有指定的this值和初始参数

    1. 구문:
<script>
        //这是一个函数
        function hello(name) {
            //this:执行上下文,程序的运行环境
            //this当前是window,全局
            this.name=name;
            console.log(this.name);
        }
        hello("天才上单");

        //bind()可以改变函数中的this指向

        //这是一个对象
        const obj={
            name :"天鹏下凡",
        };

        //bind()只绑定不执行
         let f1=hello.bind(obj,"那就这样吧!");
         console.log(f1());
 </script>
  • thisArg: 바인딩 함수 호출 시 이 매개변수로 전달됩니다. 목적 함수의 값. 바인딩된 함수를 생성하는 데 new 연산자를 사용하는 경우 이 값은 무시됩니다. 바인딩을 사용하여 setTimeout(콜백으로 제공됨)에서 함수를 생성할 때 thisArg로 전달된 모든 기본 값은 객체로 변환됩니다. bind 함수의 매개변수 목록이 비어 있거나 thisArgnull 또는 정의되지 않음인 경우 실행 범위의 this 는 새 함수의 thisArg로 처리됩니다.

  • arg1, arg2, ...: 대상 함수가 호출되면 매개변수가 바인딩된 함수의 매개변수 목록에 미리 설정됩니다.

  • 반환 값: 지정된 this

    값 합계 초기 매개변수.

    2. 예: 🎜🎜🎜🎜
    天才上单    
    那就这样吧!
    undefined
    🎜🎜🎜3. 출력🎜🎜🎜rrreee🎜추천: "🎜2021 js 인터뷰 질문 및 답변(대요약) 🎜" 🎜

위 내용은 JS의 바인딩()에 대한 간략한 토론의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.