码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • vue2升级vue3:Vue Demij打通vue2与vue3壁垒,构建通用组件


    如果你的vue2代码之前是使用vue-class-component 类组件模式写的。选择可以使用 https://github.com/facing-dev/vue-facing-decorator 来进行低成本的升级,但是升级难度还是蛮大的。

    如果你之前的vue2 版本使用的是 @vue/composition-api,那么 Vue Demi  以后可以无缝升级vue3.

     

    Vue Demi 是一个很棒的包,具有很多潜力和实用性。

    根据创建者 Anthony Fu 的说法

    Vue Demi 是一个开发实用程序,允许你为 Vue 2 和 3 编写通用 Vue 库。而无需担心用户安装的版本。

    作者Antfu的介绍博客: https://antfu.me/posts/make-libraries-working-with-vue-2-and-3

    vue-demi库:https://github.com/vueuse/vue-demi

    以前,要创建支持两个目标版本的 Vue 库,我们会使用不同的分支来分离对每个版本的支持。对于现有库来说,这是一个很好的方法,因为它们的代码库通常更稳定。

    缺点是,你需要维护两个代码库,这让你的工作量翻倍。对于想要支持Vue的两个目标版本的新Vue库来说,我不推荐这种方法。实施两次功能请求和错误修复根本就不理想。

     

    这就是 Vue Demi 的用武之地。Vue Demi 通过为两个目标版本提供通用支持来解决这个问题,这意味着您只需构建一次即可获得两个目标版本的所有优点,从而获得两全其美的优势。

    • 通用Vue库。意味着这大多数情况下不是业务开发者会直接使用到的库,主要面向库开发者(vue组件库/vue插件 等)

    • 开发工具。供库开发者使用的工具,也就是说业务开发者不实际感知到它;

    Vue Demi 扮演的角色

     

     

    在 Vue 2 中,Composition API 作为插件提供,在使用它之前需要安装在 Vue 实例上:

    1
    2
    3
    4
    import Vue from 'vue' 
    import VueCompositionAPI from '@vue/composition-api' 
     
    Vue.use(VueCompositionAPI)

    Vue Demi 会尝试自动安装它,但是对于您想要确保插件安装正确的情况,提供了 install() API 来帮助您。

    Vue Demi使用了NPM钩子postinstall。当用户安装所有包后,脚本将开始检查已安装的Vue版本,并根据Vue版本返回对应的代码。在使用Vue 2时,如果没有安装@vue/composition-api,它也会自动安装.

    它作为 Vue.use(VueCompositionAPI) 的安全版本公开:

    1
    2
    3
    import { install } from 'vue-demi' 
     
    install()

    在实际的代码中,直接用就好

    当你使用vue Api时,请从vue-demi里导入,它会自动根据用户使用的环境,而被重定向到vue@3.x或者vue@2.x + @vue/composition-api。

    当用户要创建一个Vue插件/库时,只需将vue-demi安装为依赖项并将其导入,然后像之前一样发布你的插件/库,用户的软件包就会变得通用。

    1
    2
    3
    4
    import {defineComponent, PropType, h, isVue2} from "vue-demi" 
    export default defineComponent({
      // ... 
    })

    但是还是的修改你package 代码:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    {
      "peerDependencies": {
        "@vue/composition-api": "^1.4.3",
        "vue": "^2.6.12 || >=3.2.37"
      },
      "peerDependenciesMeta": {
        "@vue/composition-api": {
          "optional": true
        }
      }
    }

     

     

    参考文章:

    使用 Vue Demi 构建通用的 Vue 组件库 https://developer.51cto.com/article/700797.html

    一库】vue-demi: 一拳打穿vue2和3的版本次元壁 https://juejin.cn/post/7032860019880099847

    Vue Demi https://madewith.cn/502

     

     


    转载本站文章《vue2升级vue3:Vue Demij打通vue2与vue3壁垒,构建通用组件》,
    请注明出处:https://www.zhoulujun.cn/html/webfront/ECMAScript/vue3/8866.html

  • 相关阅读:
    小语种翻译软件,谷歌api接口批量翻译软件
    Modbus RTU(Remote Terminal Unit)与RS-485协议介绍(主站设备(Master)、从站设备(Slave))
    SpringBoot无侵入式实现API接口统一JSON返回
    jansson库使用
    使用requests库解决Session对象设置超时的问题
    Android 获取设备内存和外存
    23种经典设计模式:单例模式篇(C++)
    Kindle电子书下载功能关闭怎么办,借助calibre和cpolar搭建私有的网络书库公网访问
    视频语音转文字工具用哪个好?推荐6款优质的视频转文字工具
    吃豆人游戏-第12届蓝桥杯Scratch选拔赛真题精选
  • 原文地址:https://www.cnblogs.com/zhoulujun/p/16519276.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号