Ionic 6 Vue项目需要使其成为SSR

ua4mk5z4  于 2023-04-12  发布在  Vue.js
关注(0)|答案(1)|浏览(150)

我有一个用vue js编写的ionic 6项目。我需要添加SSR功能并将其部署到主机。
PWA工作正常,但我需要将其转换为SSR。我使用vuex作为存储状态。
以下是当前的package.json文件:

{
    "name": "myProject",
    "version": "0.0.1",
    "private": true,
    "description": "My Project",
    "scripts": {
        "serve": "vue-cli-service serve",
        "build": "vue-cli-service build",
        "test:unit": "vue-cli-service test:unit",
        "test:e2e": "vue-cli-service test:e2e",
        "lint": "vue-cli-service lint"
    },
    "dependencies": {
        "@capacitor/app": "1.0.3",
        "@capacitor/core": "3.2.4",
        "@capacitor/device": "^1.0.3",
        "@capacitor/haptics": "1.1.0",
        "@capacitor/keyboard": "1.1.0",
        "@capacitor/status-bar": "1.0.3",
        "@ionic-native/geolocation": "^5.36.0",
        "@ionic/core": "^6.0.7",
        "@ionic/vue": "^6.0.7",
        "@ionic/vue-router": "^6.0.7",
        "@tinymce/tinymce-vue": "^4.0.5",
        "@types/bootstrap": "^5.1.6",
        "@vue-leaflet/vue-leaflet": "^0.6.1",
        "@vue/server-renderer": "^3.2.47",
        "@vuelidate/core": "^2.0.0-alpha.28",
        "@vuelidate/validators": "^2.0.0-alpha.23",
        "bootstrap": "^5.1.3",
        "card-validator": "^8.1.1",
        "core-js": "^3.6.5",
        "date-fns": "^2.28.0",
        "firebase": "^9.8.1",
        "register-service-worker": "^1.7.1",
        "vue": "^3.2.31",
        "vue-gtag": "^2.0.1",
        "vue-i18n": "^9.2.0-beta.11",
        "vue-router": "^4.0.12",
        "vue3-google-map": "^0.8.2",
        "vue3-tel-input": "^1.0.4",
        "vuex": "^4.0.2"
    },
    "devDependencies": {
        "@capacitor/cli": "3.2.4",
        "@types/jest": "^24.0.19",
        "@typescript-eslint/eslint-plugin": "^2.33.0",
        "@typescript-eslint/parser": "^2.33.0",
        "@vue/cli-plugin-babel": "~4.5.0",
        "@vue/cli-plugin-e2e-cypress": "~4.5.0",
        "@vue/cli-plugin-eslint": "~4.5.0",
        "@vue/cli-plugin-pwa": "~4.5.0",
        "@vue/cli-plugin-router": "~4.5.0",
        "@vue/cli-plugin-typescript": "~4.5.0",
        "@vue/cli-plugin-unit-jest": "~4.5.0",
        "@vue/cli-service": "~4.5.0",
        "@vue/compiler-sfc": "^3.0.0-0",
        "@vue/eslint-config-typescript": "^5.0.2",
        "@vue/test-utils": "^2.0.0-0",
        "eslint": "^6.7.2",
        "eslint-plugin-vue": "^7.0.0-0",
        "typescript": "^4.3.5",
        "vue-jest": "^5.0.0-0"
    }
}

下面是主.ts文件:

import { createApp } from "vue";
import App from "./App.vue";
import { store, key } from "./store";
import router from "./router";
import i18n from "@/i18n";
import VueGtag from "vue-gtag";
import "./registerServiceWorker";

import { IonicVue } from "@ionic/vue";

/* Core CSS required for Ionic components to work properly */
import "@ionic/vue/css/core.css";

/* Basic CSS for apps built with Ionic */
import "@ionic/vue/css/normalize.css";
import "@ionic/vue/css/structure.css";
import "@ionic/vue/css/typography.css";

/* Optional CSS utils that can be commented out */
import "@ionic/vue/css/padding.css";
import "@ionic/vue/css/float-elements.css";
import "@ionic/vue/css/text-alignment.css";
import "@ionic/vue/css/text-transformation.css";
import "@ionic/vue/css/flex-utils.css";
import "@ionic/vue/css/display.css";

/* Bootstrap */
import "bootstrap/dist/css/bootstrap.min.css";
import "bootstrap/dist/js/bootstrap.min.js";

/* Theme variables */
import "./theme/variables.css";
import "./theme/style-ar.css";
import "./theme/main.css";
import "./theme/responsive.css";
import "./theme/header.css";
import "./theme/account.css";
import "./theme/form.css";
import "./theme/uicons-regular-straight.css";

const app = createApp(App)
    .use(IonicVue)
    .use(store, key)
    .use(i18n)
    .use(router)
    .use(
        VueGtag,
        {
            appName: "PWA",
            bootstrap: false,
        },
        router
    );

router.isReady().then(() => {
    app.mount("#app");
});

我尝试了一些教程,但它没有工作。

afdcj2ne

afdcj2ne1#

据我所知,不可能将离子Vue应用程序转换为SSR页面。
一个替代方案可能是用nuxt构建一个SSR页面,然后添加电容器将其制作成移动的应用程序。当然,这种方式不能使用Ionic组件。
另一种选择是使用Quasar框架,它提供了SSR和SPA的开箱即用。https://quasar.dev/introduction-to-quasar#what-is-quasar

相关问题