6 回答
data:image/s3,"s3://crabby-images/19d0b/19d0b65d7c67434ad33fccbaf610b6233ff86f02" alt="?"
TA贡献1860条经验 获得超8个赞
CRA 不会使用默认安装命令直接为 Service Worker 提供支持,因为开发人员可能不会将应用程序制作为 PWA。因此,他们决定将其保留为可选。和我一样,如果您其他人想在创建新应用程序时安装 Service Worker,请首选:
npx create-react-app my-app --template cra-template-pwa
而不是默认的npx create-react-app my-app
.
data:image/s3,"s3://crabby-images/6fa48/6fa4861c9d5f840126b74eca259fee4c8b72bd2a" alt="?"
TA贡献1998条经验 获得超6个赞
如果您已经有现有项目并且想要迁移到新版本的 CRA,您可以按照以下步骤操作:
1 使用 Service Worker 模板在计算机上的某个位置创建一个新的 CRA:
npx create-react-app my-app --template cra-template-pwa
2 将 service-worker.js 从新创建的应用程序复制到您的 src 目录中
3 将 package.json 中的“workbox-*”依赖项复制到 package.json 依赖项中
4 (可选)如果您需要 web-vitals,请将 web-vitals 依赖项从 package.json 复制到 package.json
并且不要忘记再次运行“yarn install”或“npm install”
就是这样
data:image/s3,"s3://crabby-images/6a71d/6a71dff4fd2daeb6c4ab48b5ecdd781632be7e3b" alt="?"
TA贡献1845条经验 获得超8个赞
如果您已经存在没有模板的反应项目,则另一种解决方法:
转到文件夹index.html中的文件public并在其中添加<script>标签,您可以使用以下方式service worker从<script>标签中注册index.html:
if ("serviceWorker" in navigator) {
navigator.serviceWorker.register("/serviceworker.js")
.then(e => console.log("Service worker registered", e))
.catch(e => console.log("service worker failed", e));
}
这样您就可以缓存您的公共图标文件和图像。
data:image/s3,"s3://crabby-images/40e78/40e78179a15c2009a71a4fd9573fa07d4cd4be8b" alt="?"
TA贡献1834条经验 获得超8个赞
你需要运行这个命令
npx create-react-app your-app-name --template cra-template-pwa
代替
npx create-react-app your-app-name
data:image/s3,"s3://crabby-images/b1b94/b1b9459bad1650190187918a038473ae209ebc5a" alt="?"
TA贡献1884条经验 获得超4个赞
运行此命令“npx create-react-app your-app-name --template cra-template-pwa”而不是“npx create-react-app your-app-name”
data:image/s3,"s3://crabby-images/3e388/3e388c4133e6b8c9313f6ece31ce2d937bd4de14" alt="?"
TA贡献1773条经验 获得超3个赞
迁移全栈应用程序时,请确保执行“bukso”中的所有步骤以及:
将 serviceWorkerRegistration.js 文件添加到 src 的根目录中,就像 service-worker.js 一样
构建您的全栈应用程序,使用“npm install --globalserve”安装静态服务器
转到客户端目录并使用“serve -s build”在静态创建的构建文件夹上运行服务器
添加回答
举报