{"id":3461,"date":"2020-10-15T17:21:33","date_gmt":"2020-10-15T17:21:33","guid":{"rendered":"https:\/\/ionicframework.com\/blog\/?p=3461"},"modified":"2020-10-29T20:23:19","modified_gmt":"2020-10-29T20:23:19","slug":"announcing-ionic-vue","status":"publish","type":"post","link":"https:\/\/ionic.io\/blog\/announcing-ionic-vue","title":{"rendered":"Announcing Ionic Vue"},"content":{"rendered":"<p style=\"font-size:25px; line-height: 150%;\">Today I am thrilled to announce the release of Ionic Vue, a native Vue version of Ionic Framework that makes it easy to build apps for iOS, Android, and the web as a Progressive Web App. Ionic Vue has been written to take advantage of all the great new features that recently shipped in Vue 3.<\/p>\n<p><!--more--><\/p>\n<p>Ionic Vue represents a big milestone in Ionic Framework&#8217;s development after the release of our <a href=\"https:\/\/ionicframework.com\/blog\/announcing-ionic-react\/\">React integration<\/a> earlier in 2020. This launch is the culmination of our \u201c<a href=\"https:\/\/ionicframework.com\/blog\/introducing-ionic-4-ionic-for-everyone\/\">Ionic for Everyone<\/a>\u201d push that was kicked off in early 2019 with the release of Ionic Framework v4. As a result, I&#8217;d like to share some context as to how we got here and where we are going next.<\/p>\n<p><a href=\"https:\/\/ionicframework.com\/docs\/vue\/quickstart\">Click here<\/a> if you just want to get started building with Ionic Vue, I won&#8217;t be offended. \ud83d\ude0a<\/p>\n<h2>A bit about Ionic Framework \ud83d\udc81\u200d\u2640\ufe0f<\/h2>\n<p>If this is your first time hearing about Ionic, Hello there! \ud83d\udc4b<\/p>\n<p>Ionic Framework is an open source UI toolkit focused on building high quality mobile apps for native iOS, native Android, and the web! From the ground up, it&#8217;s built with HTML, CSS, and JavaScript, so web developers should feel right at home building with our components. Our components allow developers to build native experiences, all while using web technology. Today, Ionic powers <a href=\"https:\/\/appfigures.com\/top-sdks\/development\/apps\" rel=\"noopener\" target=\"_blank\">> 15% of all apps<\/a>.<\/p>\n<div class=\"split\">\n<figure>\n<p><img decoding=\"async\" data-src=\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-app-light.png\" alt=\"an Ionic app in light mode\" class=\"device-frames lazyload\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" style=\"--smush-placeholder-width: 1017px; --smush-placeholder-aspect-ratio: 1017\/1980;\" \/><noscript><img decoding=\"async\" src=\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-app-light.png\" alt=\"an Ionic app in light mode\" class=\"device-frames\" \/><\/noscript><br \/>\n<\/figure>\n<figure>\n<p><img decoding=\"async\" data-src=\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-app-dark.png\" alt=\"an Ionic app in dark mode\" class=\"device-frames lazyload\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" style=\"--smush-placeholder-width: 1017px; --smush-placeholder-aspect-ratio: 1017\/1980;\" \/><noscript><img decoding=\"async\" src=\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-app-dark.png\" alt=\"an Ionic app in dark mode\" class=\"device-frames\" \/><\/noscript><br \/>\n<\/figure>\n<\/div>\n<h2>A Brief History \ud83d\udcd6<\/h2>\n<p>You might recall us releasing an Ionic Vue beta back in early 2019. That version was built for Vue 2 and lacked features such as proper <code>v-model<\/code> support. While developing Ionic Vue and Ionic React side by side, we quickly realized they had a lot in common. In fact, we found ourselves implementing similar features and fixing the same bugs multiple times.<\/p>\n<p>Also around this time, the Vue team was starting to ramp up development on Vue 3, and we decided it made sense for Ionic Framework to support that version instead. We paused Ionic Vue development and shifted focus to Ionic React. With its completion, we found ourselves with all the key learnings we needed to develop Ionic Vue, and we are really happy with the way it turned out\u2026 if we may say so ourselves.<\/p>\n<h2>A Big Milestone \ud83c\udfc6<\/h2>\n<p>Since its launch in January 2019, we wanted Ionic Framework v4 to be known as <em>the<\/em> app framework for every web developer. To that extent, we lovingly referred to Ionic Framework v4 as &#8220;Ionic for Everyone.&#8221; This release rebuilt Ionic Framework from the ground up with Web Components. While this change took time, it ultimately allows us to support any framework without having to re-write Ionic Framework.<\/p>\n<p>Today, we are committed to supporting not just Angular, but also React and Vue. In a sense, the release of Ionic Vue is an indication that our efforts have paid off. Neither the React nor the Vue integrations required any major rewrites of Ionic Framework, and the Ionic API remains remarkably similar across framework integrations.<\/p>\n<p>The release of Ionic Vue demonstrates that any web developer can build performant, cross platform applications with Ionic Framework using the framework of their choice.<\/p>\n<h2>Getting Started \ud83c\udfc3\u200d\u2642\ufe0f<\/h2>\n<blockquote><p>\n  Note: The first official version of Ionic Vue is v5.4.0\n<\/p><\/blockquote>\n<p>Getting started with Ionic Vue is a breeze. First, be sure you have the latest version of the Ionic CLI installed:<\/p>\n<pre><code class=\"language-shell\">npm install -g @ionic\/cli@latest\n<\/code><\/pre>\n<blockquote><p>\n  If you used the Ionic Vue beta, be sure to update your CLI as you likely were using a pre-release version.\n<\/p><\/blockquote>\n<p>From here, we can use the Ionic CLI to create an Ionic Vue starter application:<\/p>\n<pre><code class=\"language-shell\">ionic start my-vue-app --type vue\n<\/code><\/pre>\n<p>The CLI will guide you through the setup process by first asking a few questions. Once the application has been installed, you can start the development server by running:<\/p>\n<pre><code class=\"language-shell\">ionic serve\n<\/code><\/pre>\n<p>Under the hood, the <code>ionic serve<\/code> command uses the Vue CLI to compile your app, start a dev server, and open your app in a new browser window.<\/p>\n<p>From here, we have access to all of Ionic Framework&#8217;s components:<\/p>\n<pre><code class=\"language-html\">&lt;template&gt;\n  &lt;ion-page&gt;\n    &lt;ion-header :translucent=&quot;true&quot;&gt;\n      &lt;ion-toolbar&gt;\n        &lt;ion-title&gt;Hello Vue&lt;\/ion-title&gt;\n      &lt;\/ion-toolbar&gt;\n    &lt;\/ion-header&gt;\n\n    &lt;ion-content :fullscreen=&quot;true&quot;&gt;\n      &lt;ion-header collapse=&quot;condense&quot;&gt;\n        &lt;ion-toolbar&gt;\n          &lt;ion-title size=&quot;large&quot;&gt;Hello Vue&lt;\/ion-title&gt;\n        &lt;\/ion-toolbar&gt;\n      &lt;\/ion-header&gt;\n    &lt;\/ion-content&gt;\n  &lt;\/ion-page&gt;\n&lt;\/template&gt;\n\n&lt;script&gt;\n  import { defineComponent } from &#039;vue&#039;;\n  import {\n    IonContent,\n    IonHeader,\n    IonPage,\n    IonTitle,\n    IonToolbar,\n  } from &#039;@ionic\/vue&#039;;\n  export default defineComponent({\n    name: &#039;HomePage&#039;,\n    components: {\n      IonContent,\n      IonHeader,\n      IonPage,\n      IonTitle,\n      IonToolbar,\n    },\n  });\n&lt;\/script&gt;\n<\/code><\/pre>\n<p>To use the components, you need to import them from the <code>@ionic\/vue<\/code> package and provide them to your Vue component.<\/p>\n<h3>Building upon the Vue Router \ud83e\udded<\/h3>\n<p>Like with the Angular and React versions of Ionic Framework, we chose to use the official router that is provided with Vue, <code>vue-router<\/code>. To handle Ionic Framework\u2019s animations, we have extended the Router\u2019s API through the <code>ion-router-outlet<\/code> component. This component is used in place of the typical <code>router-view<\/code> component that is used in Vue applications.<\/p>\n<p>Using this modified router is mostly the same as the regular <code>vue-router<\/code> except with a few different imports. Lazy loading works out of the box too!<\/p>\n<pre><code class=\"language-js\">import { createRouter, createWebHistory } from &#039;@ionic\/vue-router&#039;;\nimport Home from &#039;@\/views\/Home.vue&#039;\n\nconst router = createRouter({\n  history: createWebHistory(process.env.BASE_URL),\n  routes: [\n    {\n      path: &#039;\/&#039;,\n      redirect: &#039;\/home&#039;\n    },\n    {\n      path: &#039;\/home&#039;,\n      name: &#039;Home&#039;,\n      component: Home\n    },\n    {\n      path: &#039;\/lazy&#039;,\n      component: () =&gt; import(&#039;@\/views\/Lazy.vue&#039;)\n    }\n  ]\n})\n<\/code><\/pre>\n<p>Rather than import <code>createRouter<\/code> and <code>createWebHistory<\/code> from <code>vue-router<\/code>, you need to import them from <code>@ionic\/vue-router<\/code>. These imports wrap the <code>vue-router<\/code> functions of the same name and provide a few additional details that let Ionic Framework work well within the Vue environment.<\/p>\n<p>While we recommend relying on the tooling that Vue Router provides, we have added support for the <code>router-link<\/code> property on components that allow for it:<\/p>\n<pre><code class=\"language-html\">&lt;ion-item router-link=&quot;\/child-page&quot;&gt;\n  &lt;ion-label&gt;Click Me to Navigate&lt;\/ion-label&gt;\n&lt;\/ion-item&gt;\n<\/code><\/pre>\n<p>You can also specify the direction using <code>router-direction<\/code> and a custom animation using <code>router-animation<\/code>.<\/p>\n<p>For transitions and lifecycle events to work properly, each Ionic page must be wrapped in an <code>ion-page<\/code> component:<\/p>\n<pre><code class=\"language-html\">&lt;template&gt;\n  &lt;ion-page&gt; ... &lt;\/ion-page&gt;\n&lt;\/template&gt;\n\n&lt;script&gt;\n  import { defineComponent } from &#039;vue&#039;;\n  import { IonPage } from &#039;@ionic\/vue&#039;;\n  export default defineComponent({\n    name: &#039;HomePage&#039;,\n    components: { IonPage },\n  });\n&lt;\/script&gt;\n<\/code><\/pre>\n<p>Lifecycle events can be accessed by providing the appropriate event as a method:<\/p>\n<pre><code class=\"language-js\">export default defineComponent({\n  name: &#039;HomePage&#039;,\n  components: {\n    IonPage\n  },\n  methods: {\n    ionViewDidEnter: () =&gt; {\n      ...\n    },\n    ionViewDidLeave: () =&gt; {\n      ...\n    },\n    ionViewWillEnter: () =&gt; {\n      ...\n    },\n    ionViewWillLeave: () =&gt; {\n      ...\n    }\n  }\n});\n<\/code><\/pre>\n<h3>Doing Things the Vue Way \ud83d\udee0<\/h3>\n<p><code>@ionic\/vue<\/code> includes support for every Ionic Framework component except for virtual scroll. We are embracing the community-driven solutions for virtual scroll in Vue applications and will be providing more information on how to get started with these solutions soon! Using components in Ionic Vue will still feel familiar, but will use Vue\u2019s template syntax:<\/p>\n<pre><code class=\"language-html\">&lt;template&gt;\n  &lt;ion-input v-model=&quot;inputValueRef&quot; @ionInput=&quot;onChange($event)&quot;&gt;&lt;\/ion-input&gt;\n  Value: { inputValueRef }\n&lt;\/template&gt;\n\n&lt;script&gt;\n  import { defineComponent, ref } from &#039;vue&#039;;\n  import { IonInput } from &#039;@ionic\/vue&#039;;\n  export default defineComponent({\n    name: &#039;MyComponent&#039;,\n    components: { IonInput },\n    methods: {\n      onChange: (ev: CustomEvent) =&gt; {\n        ...\n      }\n    },\n    setup() {\n      const inputValueRef = ref(&#039;&#039;);\n      return { inputValueRef };\n    }\n  });\n&lt;\/script&gt;\n<\/code><\/pre>\n<p>Overlay components, such as <code>ion-modal<\/code>, can be created dynamically by importing the appropriate controller from <code>@ionic\/vue<\/code>:<\/p>\n<pre><code class=\"language-html\">&lt;template&gt;\n  &lt;ion-page&gt;\n    &lt;ion-content&gt;\n      &lt;ion-button @click=&quot;openModal()&quot;&gt;Open Modal&lt;\/ion-button&gt;\n    &lt;\/ion-content&gt;\n  &lt;\/ion-page&gt;\n&lt;\/template&gt;\n&lt;script&gt;\n  import { defineComponent } from &#039;vue&#039;;\n  import { IonButton, IonContent, IonPage, modalController } from &#039;@ionic\/vue&#039;;\n  import ModalExample from &#039;@\/components\/Modal.vue&#039;;\n  export default defineComponent({\n    name: &#039;HomePage&#039;,\n    components: { IonButton, IonContent, IonPage },\n    setup() {\n      const openModal = async () =&gt; {\n        const modal = await modalController.create({\n          component: ModalExample,\n        });\n        await modal.present();\n      };\n\n      return { openModal };\n    },\n  });\n&lt;\/script&gt;\n<\/code><\/pre>\n<p>Overlay components can also be used directly in your component&#8217;s template:<\/p>\n<pre><code class=\"language-html\">&lt;template&gt;\n  &lt;ion-page&gt;\n    &lt;ion-content&gt;\n      &lt;ion-button @click=&quot;setModal(true)&quot;&gt;Open Modal&lt;\/ion-button&gt;\n      &lt;ion-modal :is-open=&quot;isOpen&quot; @onDidDismiss=&quot;setModal(false)&quot;&gt;\n        &lt;ModalExample&gt;&lt;\/ModalExample&gt;\n      &lt;\/ion-modal&gt;\n    &lt;\/ion-content&gt;\n  &lt;\/ion-page&gt;\n&lt;\/template&gt;\n&lt;script&gt;\n  import { defineComponent, ref } from &#039;vue&#039;;\n  import { IonButton, IonContent, IonModal, IonPage } from &#039;@ionic\/vue&#039;;\n  import ModalExample from &#039;@\/components\/Modal.vue&#039;;\n  export default defineComponent({\n    name: &#039;HomePage&#039;,\n    components: { ModalExample, IonButton, IonContent, IonModal, IonPage },\n    setup() {\n      const isOpen = ref(false);\n      const setModal = (state: boolean) =&gt; (isOpen.value = state);\n\n      return { isOpen, setModal };\n    },\n  });\n&lt;\/script&gt;\n<\/code><\/pre>\n<h3>Building your way with either TypeScript or JavaScript \u270c\ufe0f<\/h3>\n<p>We love TypeScript at Ionic, and have believed for quite some time now that it\u2019s a great tool for building scalable apps. That said, we know how much the Vue community values simplicity &#8211; in their tooling, languages, and more. In fact, it\u2019s likely what drew you to Vue in the first place. Start simple &#8211; then scale up as needed.<\/p>\n<p>So, if you\u2019d prefer to use JavaScript instead of TypeScript, you can. After generating an Ionic Vue app (see above), follow these steps:<\/p>\n<ol>\n<li>Remove TypeScript dependencies:<\/li>\n<\/ol>\n<pre><code class=\"language-bash\">npm uninstall --save typescript @types\/jest @typescript-eslint\/eslint-plugin @typescript-eslint\/parser @vue\/cli-plugin-typescript\n<\/code><\/pre>\n<ol>\n<li>Change all <code>.ts<\/code> files to <code>.js<\/code>. In a blank Ionic Vue app, this should only be <code>router\/index.ts<\/code> and <code>main.ts<\/code>.<\/p>\n<\/li>\n<li>\n<p>Remove <code>@vue\/typescript\/recommended<\/code> and <code>@typescript-eslint\/no-explicit-any<\/code>: &#8216;off&#8217;, from <code>.eslintrc.js<\/code>.<\/p>\n<\/li>\n<li>\n<p>Remove <code>Array&lt;RouteRecordRaw&gt;<\/code> from <code>router\/index.js<\/code>.<\/p>\n<\/li>\n<\/ol>\n<h3>Truly native experiences with Vue \ud83d\udcf1<\/h3>\n<p>Vue does not natively support mobile app development, but fortunately, you can pair Ionic Vue with <a href=\"https:\/\/capacitorjs.com\">Capacitor<\/a>. Using Ionic\u2019s official cross-platform native runtime, you can deploy your apps as progressive web apps <em>and<\/em> iOS\/Android apps &#8211; all from the same codebase.<\/p>\n<p>Here\u2019s an example using two Capacitor APIs, the <a href=\"https:\/\/capacitorjs.com\/docs\/apis\/camera\">Camera<\/a> and <a href=\"https:\/\/capacitorjs.com\/docs\/apis\/filesystem\">Filesystem<\/a>. After opening the camera on the mobile device, the user can take a new photo, then save it to device storage.<\/p>\n<pre><code class=\"language-typescript\">const takePhoto = async () =&gt; {\n  const cameraPhoto = await Camera.getPhoto({\n    resultType: CameraResultType.Uri,\n    source: CameraSource.Camera,\n    quality: 100,\n  });\n\n  const base64Data = convertPhotoToBase64(cameraPhoto);\n\n  const savedFile = await Filesystem.writeFile({\n    path: &#039;myphoto.jpg&#039;,\n    data: base64Data,\n    directory: FilesystemDirectory.Data,\n  });\n};\n<\/code><\/pre>\n<p>Notice that there\u2019s no mention of \u201cweb\u201d, \u201ciOS\u201d, or \u201cAndroid\u201d in the code. That\u2019s because Capacitor automatically detects the platform the app is running on, and calls the appropriate native layer code. With Core APIs like these, coupled with full access to native SDKs, Capacitor empowers you to build truly native mobile apps.<\/p>\n<h2>What&#8217;s Next? \ud83d\udee3<\/h2>\n<p>For a more in-depth look at Ionic Vue, we recommend checking our <a href=\"https:\/\/ionicframework.com\/docs\/vue\/quickstart\">Quickstart Guide<\/a>. For a more hands-on experience, take a look at our <a href=\"https:\/\/ionicframework.com\/docs\/vue\/your-first-app\">Build Your First App Guide<\/a>.<\/p>\n<p>While the release of Ionic Vue is an important milestone for Ionic Framework, there is always more to do. We plan on releasing complete Server Side Rendering (SSR) support for Ionic Vue in the future. Keep an eye out for a blog post on how you can get started with that!<\/p>\n<p>In terms of general Ionic Framework development, we have a lot of exciting things planned, so stay tuned. Also, let us know where you would like to see Ionic Framework go next by tweeting at us <a href=\"https:\/\/twitter.com\/ionicframework\" rel=\"noopener\" target=\"_blank\">@ionicframework<\/a>!<\/p>\n<h2>Thank You \ud83d\udc99<\/h2>\n<p>I want to give a <strong>huge<\/strong> thank you to all the community members who helped test the Ionic Vue beta and provide feedback; this project would not have been possible without your support. Special thanks to the folks over at <a href=\"https:\/\/moduscreate.com\/\" rel=\"noopener\" target=\"_blank\">Modus Create<\/a> and specifically <a href=\"https:\/\/github.com\/michaeltintiuc\" rel=\"noopener\" target=\"_blank\">Michael Tintiuc<\/a> for helping us get Ionic Vue to where it is today.<\/p>\n<p>We are thrilled about Ionic Vue and are excited to welcome all Vue developers to the Ionic community. We are so glad you are here and cannot wait to see what you build!<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Today I am thrilled to announce the release of Ionic Vue, a native Vue version of Ionic Framework that makes it easy to build apps for iOS, Android, and the web as a Progressive Web App. Ionic Vue has been written to take advantage of all the great new features that recently shipped in Vue [&hellip;]<\/p>\n","protected":false},"author":72,"featured_media":3462,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"publish_to_discourse":"","publish_post_category":"","wpdc_auto_publish_overridden":"","wpdc_topic_tags":"","wpdc_pin_topic":"","wpdc_pin_until":"","discourse_post_id":"","discourse_permalink":"","wpdc_publishing_response":"","wpdc_publishing_error":"","_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[1,120,121],"tags":[197,147],"class_list":["post-3461","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-all","category-announcements","category-engineering","tag-ionic-vue","tag-vue"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v23.0 (Yoast SEO v23.0) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Announcing Ionic Vue - Ionic Blog<\/title>\n<meta name=\"description\" content=\"Announcing Ionic Vue - build amazing iOS, Android, and Progressive Web Apps with Vue and standard web technologies.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/ionic.io\/blog\/announcing-ionic-vue\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Announcing Ionic Vue\" \/>\n<meta property=\"og:description\" content=\"Announcing Ionic Vue - build amazing iOS, Android, and Progressive Web Apps with Vue and standard web technologies.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/ionic.io\/blog\/announcing-ionic-vue\" \/>\n<meta property=\"og:site_name\" content=\"Ionic Blog\" \/>\n<meta property=\"article:published_time\" content=\"2020-10-15T17:21:33+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2020-10-29T20:23:19+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1600\" \/>\n\t<meta property=\"og:image:height\" content=\"880\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Liam DeBeasi\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@LiamDeBeasi\" \/>\n<meta name=\"twitter:site\" content=\"@ionicframework\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Liam DeBeasi\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"10 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#article\",\"isPartOf\":{\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue\"},\"author\":{\"name\":\"Liam DeBeasi\",\"@id\":\"https:\/\/ionic.io\/blog\/#\/schema\/person\/d314e583cf08e7a28c51e8ffc3d621fa\"},\"headline\":\"Announcing Ionic Vue\",\"datePublished\":\"2020-10-15T17:21:33+00:00\",\"dateModified\":\"2020-10-29T20:23:19+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue\"},\"wordCount\":1402,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/ionic.io\/blog\/#organization\"},\"image\":{\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage\"},\"thumbnailUrl\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png\",\"keywords\":[\"Ionic Vue\",\"Vue\"],\"articleSection\":[\"All\",\"Announcements\",\"Engineering\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue\",\"url\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue\",\"name\":\"Announcing Ionic Vue - Ionic Blog\",\"isPartOf\":{\"@id\":\"https:\/\/ionic.io\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage\"},\"image\":{\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage\"},\"thumbnailUrl\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png\",\"datePublished\":\"2020-10-15T17:21:33+00:00\",\"dateModified\":\"2020-10-29T20:23:19+00:00\",\"description\":\"Announcing Ionic Vue - build amazing iOS, Android, and Progressive Web Apps with Vue and standard web technologies.\",\"breadcrumb\":{\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/ionic.io\/blog\/announcing-ionic-vue\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage\",\"url\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png\",\"contentUrl\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png\",\"width\":1600,\"height\":880},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/ionic.io\/blog\/announcing-ionic-vue#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/ionic.io\/blog\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Announcing Ionic Vue\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/ionic.io\/blog\/#website\",\"url\":\"https:\/\/ionic.io\/blog\/\",\"name\":\"ionic.io\/blog\",\"description\":\"Build amazing native and progressive web apps with the web\",\"publisher\":{\"@id\":\"https:\/\/ionic.io\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/ionic.io\/blog\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/ionic.io\/blog\/#organization\",\"name\":\"Ionic\",\"url\":\"https:\/\/ionic.io\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/ionic.io\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/white-on-color.png\",\"contentUrl\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/white-on-color.png\",\"width\":1920,\"height\":854,\"caption\":\"Ionic\"},\"image\":{\"@id\":\"https:\/\/ionic.io\/blog\/#\/schema\/logo\/image\/\"},\"sameAs\":[\"https:\/\/x.com\/ionicframework\"]},{\"@type\":\"Person\",\"@id\":\"https:\/\/ionic.io\/blog\/#\/schema\/person\/d314e583cf08e7a28c51e8ffc3d621fa\",\"name\":\"Liam DeBeasi\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/ionic.io\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/01\/ZNK4lRAJ_400x400-150x150.jpg\",\"contentUrl\":\"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/01\/ZNK4lRAJ_400x400-150x150.jpg\",\"caption\":\"Liam DeBeasi\"},\"sameAs\":[\"https:\/\/x.com\/LiamDeBeasi\"],\"url\":\"https:\/\/ionic.io\/blog\/author\/liam\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Announcing Ionic Vue - Ionic Blog","description":"Announcing Ionic Vue - build amazing iOS, Android, and Progressive Web Apps with Vue and standard web technologies.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/ionic.io\/blog\/announcing-ionic-vue","og_locale":"en_US","og_type":"article","og_title":"Announcing Ionic Vue","og_description":"Announcing Ionic Vue - build amazing iOS, Android, and Progressive Web Apps with Vue and standard web technologies.","og_url":"https:\/\/ionic.io\/blog\/announcing-ionic-vue","og_site_name":"Ionic Blog","article_published_time":"2020-10-15T17:21:33+00:00","article_modified_time":"2020-10-29T20:23:19+00:00","og_image":[{"width":1600,"height":880,"url":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png","type":"image\/png"}],"author":"Liam DeBeasi","twitter_card":"summary_large_image","twitter_creator":"@LiamDeBeasi","twitter_site":"@ionicframework","twitter_misc":{"Written by":"Liam DeBeasi","Est. reading time":"10 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue#article","isPartOf":{"@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue"},"author":{"name":"Liam DeBeasi","@id":"https:\/\/ionic.io\/blog\/#\/schema\/person\/d314e583cf08e7a28c51e8ffc3d621fa"},"headline":"Announcing Ionic Vue","datePublished":"2020-10-15T17:21:33+00:00","dateModified":"2020-10-29T20:23:19+00:00","mainEntityOfPage":{"@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue"},"wordCount":1402,"commentCount":0,"publisher":{"@id":"https:\/\/ionic.io\/blog\/#organization"},"image":{"@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage"},"thumbnailUrl":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png","keywords":["Ionic Vue","Vue"],"articleSection":["All","Announcements","Engineering"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/ionic.io\/blog\/announcing-ionic-vue#respond"]}]},{"@type":"WebPage","@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue","url":"https:\/\/ionic.io\/blog\/announcing-ionic-vue","name":"Announcing Ionic Vue - Ionic Blog","isPartOf":{"@id":"https:\/\/ionic.io\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage"},"image":{"@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage"},"thumbnailUrl":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png","datePublished":"2020-10-15T17:21:33+00:00","dateModified":"2020-10-29T20:23:19+00:00","description":"Announcing Ionic Vue - build amazing iOS, Android, and Progressive Web Apps with Vue and standard web technologies.","breadcrumb":{"@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/ionic.io\/blog\/announcing-ionic-vue"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue#primaryimage","url":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png","contentUrl":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png","width":1600,"height":880},{"@type":"BreadcrumbList","@id":"https:\/\/ionic.io\/blog\/announcing-ionic-vue#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/ionic.io\/blog"},{"@type":"ListItem","position":2,"name":"Announcing Ionic Vue"}]},{"@type":"WebSite","@id":"https:\/\/ionic.io\/blog\/#website","url":"https:\/\/ionic.io\/blog\/","name":"ionic.io\/blog","description":"Build amazing native and progressive web apps with the web","publisher":{"@id":"https:\/\/ionic.io\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/ionic.io\/blog\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/ionic.io\/blog\/#organization","name":"Ionic","url":"https:\/\/ionic.io\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/ionic.io\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/white-on-color.png","contentUrl":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/white-on-color.png","width":1920,"height":854,"caption":"Ionic"},"image":{"@id":"https:\/\/ionic.io\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/x.com\/ionicframework"]},{"@type":"Person","@id":"https:\/\/ionic.io\/blog\/#\/schema\/person\/d314e583cf08e7a28c51e8ffc3d621fa","name":"Liam DeBeasi","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/ionic.io\/blog\/#\/schema\/person\/image\/","url":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/01\/ZNK4lRAJ_400x400-150x150.jpg","contentUrl":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/01\/ZNK4lRAJ_400x400-150x150.jpg","caption":"Liam DeBeasi"},"sameAs":["https:\/\/x.com\/LiamDeBeasi"],"url":"https:\/\/ionic.io\/blog\/author\/liam"}]}},"jetpack_sharing_enabled":true,"jetpack_featured_media_url":"https:\/\/ionic.io\/blog\/wp-content\/uploads\/2020\/10\/ionic-vue-final-feature-image.png","_links":{"self":[{"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/posts\/3461","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/users\/72"}],"replies":[{"embeddable":true,"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/comments?post=3461"}],"version-history":[{"count":0,"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/posts\/3461\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/media\/3462"}],"wp:attachment":[{"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/media?parent=3461"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/categories?post=3461"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ionic.io\/blog\/wp-json\/wp\/v2\/tags?post=3461"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}