Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

🎩 Creates Universal Library for Vue 2 & 3

License

NotificationsYou must be signed in to change notification settings

vueuse/vue-demi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation


npm

Vue Demi (half in French) is a developing utility
allows you to writeUniversal Vue Libraries for Vue 2 & 3
See more details inthis blog post


Caution

vue-demi should not be used for new projects and will be deprecated in the future.


Strategies

  • <=2.6: exports fromvue +@vue/composition-api with plugin auto installing.
  • 2.7: exports fromvue (Composition API is built-in in Vue 2.7).
  • >=3.0: exports fromvue, with polyfill of Vue 2'sset anddel API.

Usage

Install this as your plugin's dependency:

npm i vue-demi# oryarn add vue-demi# orpnpm i vue-demi

Addvue and@vue/composition-api to your plugin's peer dependencies to specify what versions you support.

{"dependencies":{"vue-demi":"latest"},"peerDependencies":{"@vue/composition-api":"^1.0.0-rc.1","vue":"^2.0.0 || >=3.0.0"},"peerDependenciesMeta":{"@vue/composition-api":{"optional":true}},"devDependencies":{"vue":"^3.0.0"// or "^2.6.0" base on your preferred working environment},}

Import everything related to Vue from it, it will redirect tovue@2 +@vue/composition-api orvue@3 based on users' environments.

import{ref,reactive,defineComponent}from'vue-demi'

Publish your plugin and all is done!

When using withVite, you will need to opt-out the pre-bundling to getvue-demi work properly by

// vite.config.jsexportdefaultdefineConfig({optimizeDeps:{exclude:['vue-demi']}})

Extra APIs

Vue Demi provides extra APIs to help distinguish users' environments and to do some version-specific logic.

isVue2isVue3

import{isVue2,isVue3}from'vue-demi'if(isVue2){// Vue 2 only}else{// Vue 3 only}

Vue2

To avoid bringing in all the tree-shakable modules, we provide aVue2 export to support access to Vue 2's global API. (See#41.)

import{Vue2}from'vue-demi'if(Vue2){Vue2.config.ignoredElements.push('x-foo')}

install()

Composition API in Vue 2 is provided as a plugin and needs to be installed on the Vue instance before using. Normally,vue-demi will try to install it automatically. For some usages where you might need to ensure the plugin gets installed correctly, theinstall() API is exposed to as a safe version ofVue.use(CompositionAPI).install() in the Vue 3 environment will be an empty function (no-op).

import{install}from'vue-demi'install()

CLI

Manually Switch Versions

To explicitly switch the redirecting version, you can use these commands in your project's root.

npx vue-demi-switch 2# ornpx vue-demi-switch 3

Package Aliasing

If you would like to importvue under an alias, you can use the following command

npx vue-demi-switch 2 vue2# ornpx vue-demi-switch 3 vue3

Thenvue-demi will redirect APIs from the alias name you specified, for example:

import*asVuefrom'vue3'varisVue2=falsevarisVue3=truevarVue2=undefinedexport*from'vue3'export{Vue,Vue2,isVue2,isVue3,}

Auto Fix

If thepostinstall hook doesn't get triggered or you have updated the Vue version, try to run the following command to resolve the redirecting.

npx vue-demi-fix

Isomorphic Testings

You can support testing for both versions by adding npm alias in your dev dependencies. For example:

{"scripts": {"test:2":"vue-demi-switch 2 vue2 && jest","test:3":"vue-demi-switch 3 && jest",  },"devDependencies": {"vue":"^3.0.0","vue2":"npm:vue@2"  },}

or

{"scripts": {"test:2":"vue-demi-switch 2 && jest","test:3":"vue-demi-switch 3 vue3 && jest",  },"devDependencies": {"vue":"^2.6.0","vue3":"npm:vue@3"  },}

Examples

Seeexamples.

Who is using this?

open a PR to add your library ;)

Underhood

Seethe blog post.

License

MIT License © 2020Anthony Fu


[8]ページ先頭

©2009-2025 Movatter.jp