Mô tả
Sử dụng API chrome.devtools.inspectedWindow để tương tác với cửa sổ được kiểm tra: lấy mã thẻ cho trang được kiểm tra, đánh giá mã trong bối cảnh của cửa sổ được kiểm tra, tải lại trang hoặc lấy danh sách tài nguyên trong trang.
Xem phần Tóm tắt API DevTools để biết thông tin tổng quan về cách sử dụng API Công cụ dành cho nhà phát triển.
Thuộc tính tabId cung cấp giá trị nhận dạng thẻ mà bạn có thể sử dụng với các lệnh gọi API chrome.tabs.*. Tuy nhiên, xin lưu ý rằng API chrome.tabs.* không được hiển thị cho các trang tiện ích của Công cụ dành cho nhà phát triển do các vấn đề về bảo mật. Bạn cần phải chuyển mã thẻ sang trang nền và gọi các hàm API chrome.tabs.* từ đó.
Bạn có thể sử dụng phương thức reload để tải lại trang được kiểm tra. Ngoài ra, trình gọi có thể chỉ định một lượt ghi đè cho chuỗi tác nhân người dùng, một tập lệnh sẽ được chèn sớm khi tải trang hoặc một lựa chọn để buộc tải lại các tài nguyên được lưu vào bộ nhớ đệm.
Sử dụng lệnh gọi getResources và sự kiện onResourceContent để lấy danh sách tài nguyên (tài liệu, biểu định kiểu, tập lệnh, hình ảnh, v.v.) trong trang được kiểm tra. Bạn có thể sử dụng các phương thức getContent và
setContent của lớp Resource cùng với sự kiện onResourceContentCommitted để hỗ trợ việc sửa đổi nội dung tài nguyên, chẳng hạn như bằng một trình chỉnh sửa bên ngoài.
Tệp kê khai
Thực thi mã trong cửa sổ được kiểm tra
Phương thức eval cho phép các tiện ích thực thi mã JavaScript trong bối cảnh của trang được kiểm tra. Phương thức này rất hữu ích khi được sử dụng trong đúng bối cảnh và nguy hiểm khi được sử dụng không đúng cách. Hãy sử dụng phương thức tabs.executeScript trừ phi bạn cần chức năng cụ thể
mà phương thức eval cung cấp.
Dưới đây là những điểm khác biệt chính giữa phương thức eval và tabs.executeScript:
- Phương thức
evalkhông sử dụng một thế giới biệt lập cho mã đang được đánh giá, vì vậy, mã có thể truy cập vào trạng thái JavaScript của cửa sổ được kiểm tra. Hãy sử dụng phương thức này khi bạn cần truy cập vào trạng thái JavaScript của trang được kiểm tra. - Bối cảnh thực thi của mã đang được đánh giá bao gồm API bảng điều khiển của Công cụ dành cho nhà phát triển.
Ví dụ: mã có thể sử dụng
inspectvà$0. - Mã được đánh giá có thể trả về một giá trị được chuyển đến lệnh gọi lại của tiện ích. Giá trị được trả về phải là một đối tượng JSON hợp lệ (chỉ có thể chứa các kiểu JavaScript nguyên thuỷ và các tham chiếu không theo chu kỳ đến các đối tượng JSON khác). Hãy đặc biệt cẩn thận khi xử lý dữ liệu nhận được từ trang được kiểm tra. Bối cảnh thực thi về cơ bản được kiểm soát bởi trang được kiểm tra. Một trang độc hại có thể ảnh hưởng đến dữ liệu được trả về cho tiện ích.
Xin lưu ý rằng một trang có thể bao gồm nhiều bối cảnh thực thi JavaScript khác nhau. Mỗi khung có bối cảnh riêng, cộng với một bối cảnh bổ sung cho mỗi tiện ích có tập lệnh nội dung đang chạy trong khung đó.
Theo mặc định, phương thức eval thực thi trong bối cảnh của khung chính của trang được kiểm tra.
Phương thức eval có một đối số thứ hai không bắt buộc mà bạn có thể sử dụng để chỉ định bối cảnh mà mã được đánh giá. Đối tượng options này có thể chứa một hoặc nhiều khoá sau:
frameURL- Sử dụng để chỉ định một khung khác với khung chính của trang được kiểm tra.
contextSecurityOrigin- Sử dụng để chọn một bối cảnh trong khung đã chỉ định theo nguồn gốc trang web của khung đó.
useContentScriptContext- Nếu là true, hãy thực thi tập lệnh trong cùng bối cảnh với tập lệnh nội dung của tiện ích. (Tương đương với việc chỉ định nguồn gốc trang web của chính tiện ích làm nguồn gốc bảo mật bối cảnh.) Bạn có thể sử dụng phương thức này để trao đổi dữ liệu với tập lệnh nội dung.
Ví dụ
Mã sau đây kiểm tra phiên bản jQuery mà trang được kiểm tra sử dụng:
chrome.devtools.inspectedWindow.eval(
"jQuery.fn.jquery",
function(result, isException) {
if (isException) {
console.log("the page is not using jQuery");
} else {
console.log("The page is using jQuery v" + result);
}
}
);
Để dùng thử API này, hãy cài đặt các ví dụ về API devtools từ kho lưu trữ chrome-extension-samples.
Loại
Resource
Một tài nguyên trong trang được kiểm tra, chẳng hạn như tài liệu, tập lệnh hoặc hình ảnh.
Thuộc tính
-
url
chuỗi
URL của tài nguyên.
-
getContent
void
Lấy nội dung của tài nguyên.
Hàm
getContentcó dạng như sau:() => {...}-
returns
Promise<object>
Đang chờ xử lýMột hàm nhận nội dung tài nguyên khi yêu cầu hoàn tất.
-
-
setContent
void
Đặt nội dung của tài nguyên.
Hàm
setContentcó dạng như sau:(content: string, commit: boolean) => {...}
-
nội dung
chuỗi
Nội dung mới của tài nguyên. Hiện chỉ hỗ trợ các tài nguyên có loại văn bản.
-
cam kết
boolean
True nếu người dùng đã hoàn tất việc chỉnh sửa tài nguyên và nội dung mới của tài nguyên sẽ được duy trì; false nếu đây là một thay đổi nhỏ được gửi trong quá trình người dùng chỉnh sửa tài nguyên.
-
returns
Promise<object>
Đang chờ xử lýMột hàm được gọi khi yêu cầu hoàn tất.
-
Thuộc tính
tabId
Mã của thẻ đang được kiểm tra. Bạn có thể sử dụng mã này với chrome.tabs.* API.
Loại
số
Phương thức
eval()
chrome.devtools.inspectedWindow.eval(
expression: string,
options?: object,
): Promise<object>
Đánh giá một biểu thức JavaScript trong bối cảnh của khung chính của trang được kiểm tra. Biểu thức phải đánh giá thành một đối tượng tuân thủ JSON, nếu không, một ngoại lệ sẽ được đưa ra. Hàm eval có thể báo cáo lỗi ở phía DevTools hoặc ngoại lệ JavaScript xảy ra trong quá trình đánh giá. Trong cả hai trường hợp, tham số result của lệnh gọi lại là undefined. Trong trường hợp lỗi ở phía DevTools, tham số isException không phải là giá trị rỗng và có isError được đặt thành true và code được đặt thành mã lỗi. Trong trường hợp lỗi JavaScript, isException được đặt thành true và value được đặt thành giá trị chuỗi của đối tượng được đưa ra.
Thông số
-
biểu thức
chuỗi
Một biểu thức để đánh giá.
-
tùy chọn
đối tượng không bắt buộc
Tham số options có thể chứa một hoặc nhiều lựa chọn.
-
frameURL
chuỗi không bắt buộc
Nếu được chỉ định, biểu thức sẽ được đánh giá trên iframe có URL khớp với URL được chỉ định. Theo mặc định, biểu thức được đánh giá trong khung trên cùng của trang được kiểm tra.
-
scriptExecutionContext
chuỗi không bắt buộc
Chrome 107+Đánh giá biểu thức trong bối cảnh của tập lệnh nội dung của một tiện ích khớp với nguồn gốc được chỉ định. Nếu được cung cấp, scriptExecutionContext sẽ ghi đè chế độ cài đặt "true" trên useContentScriptContext.
-
useContentScriptContext
boolean không bắt buộc
Đánh giá biểu thức trong bối cảnh của tập lệnh nội dung của tiện ích gọi, với điều kiện là tập lệnh nội dung đã được chèn vào trang được kiểm tra. Nếu không, biểu thức sẽ không được đánh giá và lệnh gọi lại sẽ được gọi với tham số ngoại lệ được đặt thành một đối tượng có trường
isErrorđược đặt thành true và trườngcodeđược đặt thànhE_NOTFOUND.
-
Giá trị trả về
-
Promise<object>
Đang chờ xử lýMột hàm được gọi khi quá trình đánh giá hoàn tất.
getResources()
chrome.devtools.inspectedWindow.getResources(): Promise<Resource[]>
Truy xuất danh sách tài nguyên từ trang được kiểm tra.
Giá trị trả về
-
Promise<Resource[]>
Đang chờ xử lýMột hàm nhận danh sách tài nguyên khi yêu cầu hoàn tất.
reload()
chrome.devtools.inspectedWindow.reload(
reloadOptions?: object,
): void
Tải lại trang được kiểm tra.
Thông số
-
reloadOptions
đối tượng không bắt buộc
-
ignoreCache
boolean không bắt buộc
Khi là true, trình tải sẽ bỏ qua bộ nhớ đệm cho tất cả tài nguyên của trang được kiểm tra đã tải trước khi sự kiện
loadđược kích hoạt. Hiệu ứng này tương tự như việc nhấn tổ hợp phím Ctrl+Shift+R trong cửa sổ được kiểm tra hoặc trong cửa sổ Công cụ dành cho nhà phát triển. -
injectedScript
chuỗi không bắt buộc
Nếu được chỉ định, tập lệnh sẽ được chèn vào mọi khung của trang được kiểm tra ngay khi tải, trước bất kỳ tập lệnh nào của khung. Tập lệnh sẽ không được chèn sau các lần tải lại tiếp theo, ví dụ: nếu người dùng nhấn tổ hợp phím Ctrl+R.
-
userAgent
chuỗi không bắt buộc
Nếu được chỉ định, chuỗi này sẽ ghi đè giá trị của tiêu đề HTTP
User-Agentđược gửi trong khi tải tài nguyên của trang được kiểm tra. Chuỗi này cũng sẽ ghi đè giá trị của thuộc tínhnavigator.userAgentđược trả về cho mọi tập lệnh đang chạy trong trang được kiểm tra.
-
Sự kiện
onResourceAdded
chrome.devtools.inspectedWindow.onResourceAdded.addListener(
callback: function,
)
Được kích hoạt khi một tài nguyên mới được thêm vào trang được kiểm tra.
Thông số
-
callback
hàm
Tham số
callbackcó dạng như sau:(resource: Resource) => void
-
tài nguyên
-
onResourceContentCommitted
chrome.devtools.inspectedWindow.onResourceContentCommitted.addListener(
callback: function,
)
Được kích hoạt khi một bản sửa đổi mới của tài nguyên được cam kết (ví dụ: người dùng lưu phiên bản đã chỉnh sửa của tài nguyên trong Công cụ dành cho nhà phát triển).
Thông số
-
callback
hàm
Tham số
callbackcó dạng như sau:(resource: Resource, content: string) => void
-
tài nguyên
-
nội dung
chuỗi
-