화살표 함수 및 IE 11 호환성: 구문 오류 이해
JavaScript 프로그래밍 영역에서 화살표 함수는 함수 정의를 위한 간결한 구문을 제공합니다. . 그러나 이러한 기능은 Internet Explorer 11(IE 11)을 포함한 이전 브라우저와 항상 호환되지 않을 수 있습니다.
제공된 코드 조각의 경우:
g.selectAll(".mainBars") .append("text") .attr("x", d => (d.part == "primary" ? -40 : 40)) .attr("y", d => +6) .text(d => d.key) .attr("text-anchor", d => (d.part == "primary" ? "end" : "start"));
이 코드가 IE 11에서 실행하면 구문 오류가 발생합니다. 근본적인 이유는 ES6(ECMAScript 2015)에서 도입됐지만 IE 11에서는 지원되지 않는 화살표 함수를 사용하기 때문이다.
호환성 문제 극복
코드가 IE 11과 호환되도록 하려면 화살표 함수를 기존 함수 선언으로 바꿔야 합니다. 해당 ES5 코드는 다음과 유사합니다.
g.selectAll(".mainBars").append("text").attr("x", function (d) { return d.part == "primary" ? -40 : 40; }).attr("y", function (d) { return +6; }).text(function (d) { return d.key; }).attr("text-anchor", function (d) { return d.part == "primary" ? "end" : "start"; });
기존 함수 선언을 활용하면 이 수정된 코드가 IE 11에서 성공적으로 실행되어 의도한 기능을 유지합니다. 기존 함수에는 화살표 함수와 비교하여 this 키워드를 바인딩하는 규칙이 다르기 때문에 JavaScript 버전 간에 코드를 전환할 때 이러한 차이점을 고려해야 합니다.
위 내용은 IE11에서 화살표 기능이 작동하지 않는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!