イオンフレームワークベータV 6とVUEJS


VITE +イオンV 6 + Vuejs


V 6公式リリースに更新されて、このブランチを見てください


イオンが発表したのでbeta for v6 , 私はイオンを使用し始めることができるかどうか見たかったViteJS

If you want to understand more why Vite was created and what its benefits are, you can read here


私がしたアプローチは、VITEでVUEJSプロジェクトを作成するための指示に従って、次にイオンのものを追加することです.それから、Viteを加えてください、私に知らせてください.
  • https://vitejs.dev/guide/#scaffolding-your-first-vite-project
  • VITEプロジェクトを作成した後、イオンフレームワークv 6のベータ版をインストールする必要があります

  • https://github.com/ionic-team/ionic-framework/blob/next/BETA.md
  • // install latest vue
    npm install vue@next vue-router@4
    
    // install latest ionic beta
    npm install @ionic/vue@next @ionic/vue-router@next
    
    Webpackを使用していないので、他のステップは必要ないと思います

    ここでは既知の問題がある。

  • https://github.com/ionic-team/ionic-framework/issues/23539
  • 基本的に使用する必要があります"vue": "^3.0.11", そして、あなたのパッケージの更新を行います.JSONファイル.

    プロジェクトイオン


    次のステップは、VUEプロジェクトにすべてのイオン特定のものを追加します.私は、私のgithub repoですべてのものを扱うテンプレートプロジェクトを利用できます、しかし、下で、私はこの仕事をするために変化を概説しました.
    変更のほとんどはmain.ts ここでイオンとすべての必要なCSSをインポートする必要があります.
    import { createApp } from 'vue'
    import App from './App.vue'
    
    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';
    
    /* Theme variables - copied from existing project */
    import './theme/variables.css';
    
    // be sure to add the use(IonicVue)
    createApp(App).use(IonicVue).mount('#app')
    
    このファイルをプロジェクトの場所を修正する./theme/variables.css
    /* Ionic Variables and Theming. For more info, please see:
    http://ionicframework.com/docs/theming/ */
    
    /** Ionic CSS Variables **/
    :root {
      /** primary **/
      --ion-color-primary: #3880ff;
      --ion-color-primary-rgb: 56, 128, 255;
      --ion-color-primary-contrast: #ffffff;
      --ion-color-primary-contrast-rgb: 255, 255, 255;
      --ion-color-primary-shade: #3171e0;
      --ion-color-primary-tint: #4c8dff;
    
      /** secondary **/
      --ion-color-secondary: #3dc2ff;
      --ion-color-secondary-rgb: 61, 194, 255;
      --ion-color-secondary-contrast: #ffffff;
      --ion-color-secondary-contrast-rgb: 255, 255, 255;
      --ion-color-secondary-shade: #36abe0;
      --ion-color-secondary-tint: #50c8ff;
    
      /** tertiary **/
      --ion-color-tertiary: #5260ff;
      --ion-color-tertiary-rgb: 82, 96, 255;
      --ion-color-tertiary-contrast: #ffffff;
      --ion-color-tertiary-contrast-rgb: 255, 255, 255;
      --ion-color-tertiary-shade: #4854e0;
      --ion-color-tertiary-tint: #6370ff;
    
      /** success **/
      --ion-color-success: #2dd36f;
      --ion-color-success-rgb: 45, 211, 111;
      --ion-color-success-contrast: #ffffff;
      --ion-color-success-contrast-rgb: 255, 255, 255;
      --ion-color-success-shade: #28ba62;
      --ion-color-success-tint: #42d77d;
    
      /** warning **/
      --ion-color-warning: #ffc409;
      --ion-color-warning-rgb: 255, 196, 9;
      --ion-color-warning-contrast: #000000;
      --ion-color-warning-contrast-rgb: 0, 0, 0;
      --ion-color-warning-shade: #e0ac08;
      --ion-color-warning-tint: #ffca22;
    
      /** danger **/
      --ion-color-danger: #eb445a;
      --ion-color-danger-rgb: 235, 68, 90;
      --ion-color-danger-contrast: #ffffff;
      --ion-color-danger-contrast-rgb: 255, 255, 255;
      --ion-color-danger-shade: #cf3c4f;
      --ion-color-danger-tint: #ed576b;
    
      /** dark **/
      --ion-color-dark: #222428;
      --ion-color-dark-rgb: 34, 36, 40;
      --ion-color-dark-contrast: #ffffff;
      --ion-color-dark-contrast-rgb: 255, 255, 255;
      --ion-color-dark-shade: #1e2023;
      --ion-color-dark-tint: #383a3e;
    
      /** medium **/
      --ion-color-medium: #92949c;
      --ion-color-medium-rgb: 146, 148, 156;
      --ion-color-medium-contrast: #ffffff;
      --ion-color-medium-contrast-rgb: 255, 255, 255;
      --ion-color-medium-shade: #808289;
      --ion-color-medium-tint: #9d9fa6;
    
      /** light **/
      --ion-color-light: #f4f5f8;
      --ion-color-light-rgb: 244, 245, 248;
      --ion-color-light-contrast: #000000;
      --ion-color-light-contrast-rgb: 0, 0, 0;
      --ion-color-light-shade: #d7d8da;
      --ion-color-light-tint: #f5f6f9;
    }
    
    @media (prefers-color-scheme: dark) {
      /*
       * Dark Colors
       * -------------------------------------------
       */
    
      body {
        --ion-color-primary: #428cff;
        --ion-color-primary-rgb: 66,140,255;
        --ion-color-primary-contrast: #ffffff;
        --ion-color-primary-contrast-rgb: 255,255,255;
        --ion-color-primary-shade: #3a7be0;
        --ion-color-primary-tint: #5598ff;
    
        --ion-color-secondary: #50c8ff;
        --ion-color-secondary-rgb: 80,200,255;
        --ion-color-secondary-contrast: #ffffff;
        --ion-color-secondary-contrast-rgb: 255,255,255;
        --ion-color-secondary-shade: #46b0e0;
        --ion-color-secondary-tint: #62ceff;
    
        --ion-color-tertiary: #6a64ff;
        --ion-color-tertiary-rgb: 106,100,255;
        --ion-color-tertiary-contrast: #ffffff;
        --ion-color-tertiary-contrast-rgb: 255,255,255;
        --ion-color-tertiary-shade: #5d58e0;
        --ion-color-tertiary-tint: #7974ff;
    
        --ion-color-success: #2fdf75;
        --ion-color-success-rgb: 47,223,117;
        --ion-color-success-contrast: #000000;
        --ion-color-success-contrast-rgb: 0,0,0;
        --ion-color-success-shade: #29c467;
        --ion-color-success-tint: #44e283;
    
        --ion-color-warning: #ffd534;
        --ion-color-warning-rgb: 255,213,52;
        --ion-color-warning-contrast: #000000;
        --ion-color-warning-contrast-rgb: 0,0,0;
        --ion-color-warning-shade: #e0bb2e;
        --ion-color-warning-tint: #ffd948;
    
        --ion-color-danger: #ff4961;
        --ion-color-danger-rgb: 255,73,97;
        --ion-color-danger-contrast: #ffffff;
        --ion-color-danger-contrast-rgb: 255,255,255;
        --ion-color-danger-shade: #e04055;
        --ion-color-danger-tint: #ff5b71;
    
        --ion-color-dark: #f4f5f8;
        --ion-color-dark-rgb: 244,245,248;
        --ion-color-dark-contrast: #000000;
        --ion-color-dark-contrast-rgb: 0,0,0;
        --ion-color-dark-shade: #d7d8da;
        --ion-color-dark-tint: #f5f6f9;
    
        --ion-color-medium: #989aa2;
        --ion-color-medium-rgb: 152,154,162;
        --ion-color-medium-contrast: #000000;
        --ion-color-medium-contrast-rgb: 0,0,0;
        --ion-color-medium-shade: #86888f;
        --ion-color-medium-tint: #a2a4ab;
    
        --ion-color-light: #222428;
        --ion-color-light-rgb: 34,36,40;
        --ion-color-light-contrast: #ffffff;
        --ion-color-light-contrast-rgb: 255,255,255;
        --ion-color-light-shade: #1e2023;
        --ion-color-light-tint: #383a3e;
      }
    
      /*
       * iOS Dark Theme
       * -------------------------------------------
       */
    
      .ios body {
        --ion-background-color: #000000;
        --ion-background-color-rgb: 0,0,0;
    
        --ion-text-color: #ffffff;
        --ion-text-color-rgb: 255,255,255;
    
        --ion-color-step-50: #0d0d0d;
        --ion-color-step-100: #1a1a1a;
        --ion-color-step-150: #262626;
        --ion-color-step-200: #333333;
        --ion-color-step-250: #404040;
        --ion-color-step-300: #4d4d4d;
        --ion-color-step-350: #595959;
        --ion-color-step-400: #666666;
        --ion-color-step-450: #737373;
        --ion-color-step-500: #808080;
        --ion-color-step-550: #8c8c8c;
        --ion-color-step-600: #999999;
        --ion-color-step-650: #a6a6a6;
        --ion-color-step-700: #b3b3b3;
        --ion-color-step-750: #bfbfbf;
        --ion-color-step-800: #cccccc;
        --ion-color-step-850: #d9d9d9;
        --ion-color-step-900: #e6e6e6;
        --ion-color-step-950: #f2f2f2;
    
        --ion-toolbar-background: #0d0d0d;
    
        --ion-item-background: #000000;
    
        --ion-card-background: #1c1c1d;
      }
    
      /*
       * Material Design Dark Theme
       * -------------------------------------------
       */
    
      .md body {
        --ion-background-color: #121212;
        --ion-background-color-rgb: 18,18,18;
    
        --ion-text-color: #ffffff;
        --ion-text-color-rgb: 255,255,255;
    
        --ion-border-color: #222222;
    
        --ion-color-step-50: #1e1e1e;
        --ion-color-step-100: #2a2a2a;
        --ion-color-step-150: #363636;
        --ion-color-step-200: #414141;
        --ion-color-step-250: #4d4d4d;
        --ion-color-step-300: #595959;
        --ion-color-step-350: #656565;
        --ion-color-step-400: #717171;
        --ion-color-step-450: #7d7d7d;
        --ion-color-step-500: #898989;
        --ion-color-step-550: #949494;
        --ion-color-step-600: #a0a0a0;
        --ion-color-step-650: #acacac;
        --ion-color-step-700: #b8b8b8;
        --ion-color-step-750: #c4c4c4;
        --ion-color-step-800: #d0d0d0;
        --ion-color-step-850: #dbdbdb;
        --ion-color-step-900: #e7e7e7;
        --ion-color-step-950: #f3f3f3;
    
        --ion-item-background: #1e1e1e;
    
        --ion-toolbar-background: #1f1f1f;
    
        --ion-tab-bar-background: #1f1f1f;
    
        --ion-card-background: #1e1e1e;
      }
    }
    

    アクセスURL


    router/index.ts ファイルをベースURLの環境変数にアクセスする必要がある
    // https://vitejs.dev/guide/env-and-mode.html
    const router = createRouter({
        history: createWebHistory(import.meta.env.BASE_URL),
        routes
    })
    

    プロジェクトの実行


    npm run dev
    

    ビデオ


    ソースコード


    アーロンフンダース / AIVICV 6 - BETA -ブライト計画- 1


    VIEJSとVITEによるイオンスターターテンプレート


    イオンフレームワークベータV 6とVUEJS

  • このテンプレートを使用すると、VITEでイオン、Vue 3とTypesScriptで開発を開始することができます.
  • このブログ投稿の詳細情報を参照してください.
  • 閉じるこの動画はお気に入りから削除されています
  • IDEセットアップの推奨


    VSCode + Vetur . 有効にするvetur.experimental.templateInterpolationService 設定で!

    を使用する場合


    <script setup> は現在、RFCステージにある機能です.構文の適切なIDEサポートを取得するにはVolar veturの代わりに(と無効にvetur).

    タイプサポート.TSにおけるVue輸入


    タイプスクリプトはタイプ情報を扱うことができないので.vue インポートでは、デフォルトでジェネリックVueコンポーネント型として扱われます.ほとんどの場合、テンプレートの外側のコンポーネントプロップタイプを本当に気にしないなら、これはすばらしいです.ただし、実際のプロップタイプを.vue 輸入(例えば得る).
    View on GitHub