chrome.tabs.query를 사용한 비동기 결과
chrome.tabs.query를 호출할 때 다음으로 인해 예상 결과가 즉시 제공되지 않을 수 있습니다.
비동기 이해
비동기 함수는 실제 결과를 받기 위해 외부 엔터티에서 실행해야 하는 콜백 함수를 반환합니다. 콜백 함수는 일반적으로 결과가 제공되면 호출됩니다.
chrome.tabs.query의 예
다음의 단순화된 코드 조각을 고려하세요.
<code class="javascript">var fourmTabs = new Array(); chrome.tabs.query({}, function (tabs) { fourmTabs = tabs; console.log(fourmTabs[0].url); });</code>
이 예에서는 chrome.tabs.query 메소드를 사용하여 열려 있는 모든 탭을 비동기적으로 검색합니다. 그러나 fourmTabs 배열이 아직 결과로 업데이트되지 않았기 때문에 후속 console.log 문은 실패합니다.
해결책
결과에 액세스하려면 코드 이에 의존하는 항목은 아래와 같이 콜백 함수 내에 배치되어야 합니다.
<code class="javascript">var fourmTabs = new Array(); chrome.tabs.query({}, function (tabs) { fourmTabs = tabs; for (var i = 0; i < fourmTabs.length; i++) { if (fourmTabs[i] != null) console.log(fourmTabs[i].url); else { console.log("??" + i); } } });</code>
콜백 함수 내에 코드를 배치하면 fourmTabs 배열이 코드가 실행됩니다.
위 내용은 chrome.tabs.query로 비동기 결과를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!