瀏覽網站時發現有些功能不夠好,除了安裝套件外,我們還可以自己動手修改,只要執行自訂的 JavaScript ,幾乎可以把網站改成任何樣式。
但是要怎麼樣執行腳本?每次都在 F12 的主控台執行嗎?
我們可以透過 Tampermonkey 這個瀏覽器擴充套件,他最主要的功能就是執行我們的 JavaScript,方便我們修改網頁,本篇就來示範撰寫 Tampermonkey 的腳本,實現自己需要的功能!
點選「新增擴充功能」
FireFox 、 Edge 等瀏覽器也可以到各自的商店下載安裝。
就會出現 Tampermonkey 內建的編輯器,在這裡就可以完成腳本的開發。
預設內容如下:
==UserScript== 是 Tampermonkey 腳本的資訊區塊,各參數用途如下:
icon 可以使用網路上的 png to base64 工具 取得 base64 字串,就可以貼上使用。
按下 Ctrl + S 儲存後可以到「已安裝的使用者腳本」中看到該腳本,目前已經在執行中
這時候開啟 Google Map 的網頁,連畫面還沒載入完就會出現提示訊息:
如果想要等畫面載入完成可以這樣做:
我們還可以動態將按鈕加入到畫面上,這裡使用一個計時器等待元素載入完成,然後再動態產生元素並插入:
話說「等待元素出現後再處理」這個功能很常會使用到,我們可以重構一下,方便復用:
Tampermonkey 除了可以修改/增加元素外,還可以攔截、呼叫 API 、儲存檔案等,有機會再繼續來示範
參考資料:
Tampermonkey
但是要怎麼樣執行腳本?每次都在 F12 的主控台執行嗎?
我們可以透過 Tampermonkey 這個瀏覽器擴充套件,他最主要的功能就是執行我們的 JavaScript,方便我們修改網頁,本篇就來示範撰寫 Tampermonkey 的腳本,實現自己需要的功能!
安裝 Tampermonkey 套件
開啟 Chrome 線上應用程式商店,點選右上角的「加到 Chrome」點選「新增擴充功能」
FireFox 、 Edge 等瀏覽器也可以到各自的商店下載安裝。
建立第一個腳本
找到工具列上的 Tampermonkey 圖示,使用滑鼠左鍵點擊後再點擊選單的「新增腳本」就會出現 Tampermonkey 內建的編輯器,在這裡就可以完成腳本的開發。
預設內容如下:
// ==UserScript==
// @name New Userscript
// @namespace http://tampermonkey.net/
// @version 2023-12-15
// @description try to take over the world!
// @author You
// @match http://*/*
// @icon 
// @grant none
// ==/UserScript==
(function() {
'use strict';
// Your code here...
})();
==UserScript== 是 Tampermonkey 腳本的資訊區塊,各參數用途如下:
- name: 腳本名稱
- namespace: 命名空間,腳本的網址或是作者的網址
- version: 腳本的版本號碼
- description: 描述,說明腳本功能
- author: 作者
- match: 要在哪些網址中執行
- icon: 腳本的小圖示,使用 base64 編碼的圖片
- grant: 標記需要的權限
// ==UserScript==
// @name My first script
// @namespace http://ruyut.com/
// @version 2023-12-15
// @description 這個是描述
// @author Ruyut
// @match https://www.google.com/maps/*
// @icon 
// @grant none
// ==/UserScript==
(function() {
'use strict';
alert("腳本啟動!");
})();
icon 可以使用網路上的 png to base64 工具 取得 base64 字串,就可以貼上使用。
按下 Ctrl + S 儲存後可以到「已安裝的使用者腳本」中看到該腳本,目前已經在執行中
這時候開啟 Google Map 的網頁,連畫面還沒載入完就會出現提示訊息:
如果想要等畫面載入完成可以這樣做:
window.addEventListener('load', function () {
console.log('整個網頁載入完成');
});
我們還可以動態將按鈕加入到畫面上,這裡使用一個計時器等待元素載入完成,然後再動態產生元素並插入:
const intervalId = setInterval(function () {
const targetElement = document.querySelector('#gb > div > div > div.gb_Od.gb_Wf.gb_C');
if (targetElement) {
clearInterval(intervalId); // 停止計時器
// 建立新按鈕
const newButton = document.createElement('button');
newButton.textContent = '新按鈕';
// 加上圓角邊框
newButton.style.borderRadius = '5px';
newButton.style.border = '1px solid #d1d5db';
// 加上按鈕事件
newButton.addEventListener('click', function () {
alert('按鈕被按下');
});
// 在第一個元素之前插入新按鈕
targetElement.insertBefore(newButton, targetElement.firstChild);
}
}, 200); // 每隔 0.2 秒檢查一次目標元素是否存在
話說「等待元素出現後再處理」這個功能很常會使用到,我們可以重構一下,方便復用:
/**
* 等待目標元素存在後,執行傳入的匿名函式
* @param selector
* @param action
* @param interval
*/
function doWhenElementExists(selector, action, interval = 200) {
const intervalId = setInterval(function () {
const targetElement = document.querySelector(selector);
if (targetElement) {
clearInterval(intervalId); // 停止計時器
action(targetElement); // 執行傳入的匿名函式
}
}, interval);
}
doWhenElementExists(
'#gb > div > div > div.gb_Od.gb_Wf.gb_C',
(targetElement) => {
// 建立新按鈕
const newButton = document.createElement('button');
newButton.textContent = '新按鈕';
// 加上圓角邊框
newButton.style.borderRadius = '5px';
newButton.style.border = '1px solid #d1d5db';
// 加上按鈕事件
newButton.addEventListener('click', function () {
alert('按鈕被按下');
});
// 在第一個元素之前插入新按鈕
targetElement.insertBefore(newButton, targetElement.firstChild);
}
);
Tampermonkey 除了可以修改/增加元素外,還可以攔截、呼叫 API 、儲存檔案等,有機會再繼續來示範
參考資料:
Tampermonkey
留言
張貼留言
如果有任何問題、建議、想說的話或文章題目推薦,都歡迎留言或來信: a@ruyut.com