PWA For iOS (Progressive Web App For Any Site)

Turn any site into a PWA.

目前為 2025-11-28 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript== 
// @name        PWA For iOS (Progressive Web App For Any Site)
// @namespace   Violentmonkey Scripts
// @match       *://*/*
// @grant       none
// @version     1.0
// @author      LieFlatandSleep
// @description Turn any site into a PWA. 
// ==/UserScript==

function getSiteName() {
    const title = document.title?.trim();
    if (title && title.length > 0) return title;

    const host = window.location.hostname
        .replace(/^www\./, '')
        .replace(/\.[^.]+$/, ''); 

    return host.charAt(0).toUpperCase() + host.slice(1);
}

const siteName = encodeURIComponent(getSiteName());


const manifestLink = document.createElement('link');
manifestLink.rel = 'manifest';
manifestLink.href = `https://api.lowtechguys.com/manif?name=${siteName}`;


const head = document.head || document.getElementsByTagName('head')[0];


if (head) {
    head.appendChild(manifestLink);
    console.log('Manifest injected for:', siteName);
} else {
    // If head doesn't exist yet, wait for it
    new MutationObserver((mutations, observer) => {
        const h = document.head;
        if (h) {
            h.appendChild(manifestLink);
            console.log('Manifest injected (late) for:', siteName);
            observer.disconnect();
        }
    }).observe(document.documentElement, { childList: true, subtree: true });
}