Vue3全家桶 - Vue3 - 【1】前置准备和介绍(VsCode插件 + 组合式API和选项式API的比较)

一、前言

  • Vue2.7是当前、同时也是最后一个 Vue2.x 的次级版本更新。Vue2.7 会以其发布日期,即2022年7月1日开始计算,提供18个月的长期技术支持。在此期间,Vue2将会提供必要的bug修复和安全修复。但不再提供新特性。
  • Vue2的终止支持时间是2023年12月31日。在此之后,Vue2在已经已有的分发渠道中仍然可以使用,但不再进行更新,包括对安全问题和浏览器兼容性问题的修复等。
  • 学习 Vue3 已经是不可避免的了,不管从自身技术提升还是公司项目技术选型来看。
  • 后续会慢慢补充各种东西,包括一些在项目中遇到的问题或代码的一些简化写法。
  • 插件的选择:
    • Vue3:
      • image.png
    • Vue2:
      • image.png
    • 两个插件不能同时启用。
    • 禁用 Vue2 的插件之后,可能没法生成基本代码了,这块可以自己配置一下:
    • 详细见VScode 配置 vue2 / vue3 基本模板 代码;
  • 给孩子点点关注吧!😭
    image.png

二、简介

2.1 MVVM工作原理

  • MVVM指的是 ModelViewViewModel
    • Model:页面渲染 用到的 数据源
    • View:页面 所渲染 的 DOM结构
    • ViewModel:表示 Vue实例
  • image.png
  • 当数据源发生变化时,会被 VM 监听到,VM会根据最新的数据源自动更新页面的结构;
  • 当表单元素的值发生变化时,也会被VM监听到,VM会把变化后最新的值自动同步到Model数据源中。

2.2 Vue3项目的创建

  • 可以去看我的另一篇文章《从 0~1 创建 Vue3 + JS 项目》

2.3 组合式API / 选项式API

  • 可以去看看官网上面的两种API;
  • 组合式API:
    • Vue3全家桶笔记中大部分是组合式API(在Vue3中我还是喜欢组合式),选项式API比较少(选项式写法和Vue2类似,只是有些方法不同);
    • 通过组合式API,我们可以使用导入的API函数来描述组件逻辑;
    • 在单文件组件中,组合式API通常会与<script setup>搭配使用(后面会讲到这个 setup 语法糖);
    • 这个 setup 属性是一个标识,告诉Vue需要在编译时进行一些处理,让我们可以更简洁地使用组合式API;
    • <script setup> 中导入的 顶层变量 和 函数 都能够在 模板中 直接使用
  • 选项式API:
    • 参考Vue2全家桶笔记。
    • Vue2的语法(写法很类似,有些方法不一样),在Vue3中也是支持的;
    • 使用选项式API,我们可以用包含多个选项的对象来描述组件的逻辑,例如datamethodsmounted
    • 选项所定义的属性都会暴露在函数内部的this上,它会指向当前的组件实例;
  • 在Vue3中使用组合式API的注意点:
    • 如果在 组合式API 中直接声明 普通变量 的数据源,他们并 不具备响应式
      • 🔺注意:
        • 可以正常显示在页面上;
        • 视图改变会触发数据的更新(手动改变输入框的值,Vue中的数据会发生变化);
        • 但数据的更新并不会同步到视图中(点击按钮的时候,数据会发生变化,但是不会同步到视图上);
      • image.png
      • 视图数据更新之后,有时候需要点击devtools面板的刷新按钮(有些版本的需要点击刷新按钮才能看到结果);
      • App.vue中的代码:
        <script setup>
        // 普通变量的数据源(基本数据类型),不具备响应式
        let account = 123456// 不同变量的数据源(引用数据类型),不具备响应式
        let obj = {age: 22
        }function changeAccount() {account++
        }function changeAge() {obj.age++
        }
        </script><template><div><input type="text" v-model="account"><button @click="account++"> 在 template 中使用 account </button><button @click="changeAccount"> 在 script 中使用 account </button><br><hr><input type="text" v-model="obj.age"><button @click="obj.age++"> 在 template 中使用 account </button><button @click="changeAge"> 在 script 中使用 account </button></div>
        </template>
        
    • 演示效果:e3f45a65-b8f2-4803-aa9d-2282afdeb4f8.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/740178.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C语言步行梯】自定义函数、函数递归详谈

&#x1f3af;每日努力一点点&#xff0c;技术进步看得见 &#x1f3e0;专栏介绍&#xff1a;【C语言步行梯】专栏用于介绍C语言相关内容&#xff0c;每篇文章将通过图片代码片段网络相关题目的方式编写&#xff0c;欢迎订阅~~ 文章目录 什么是函数库函数自定义函数函数执行示例…

Python docx学习笔记

个人学习笔记。 1 工具介绍 python-docx 是用于创建可修改 微软 Word 的一个 python 库&#xff0c;提供全套的 Word 操作&#xff0c;是最常用的 Word 工具。 1.1 基本概念 Document&#xff1a;是一个 Word 文档 对象&#xff0c;不同于 VBA 中 Worksheet 的概念&#xf…

李彦宏最新发声,“程序员”职业将不复存在!

文章目录 “程序员”职业不存在周鸿祎的看法我怎么看 昨天&#xff0c;百度一则新闻冲上了微博和知乎热搜。 “程序员”职业不存在 关于李彦宏的这个观点&#xff0c;瞬间激起热烈讨论。有赞同的、有直接开喷的&#xff0c;也有看热闹不嫌事大的。还有网友将这个问题抛给你百度…

嵌入式系统工程师错题总结

笔者来介绍一下嵌入式系统工程师考试的一些易错题目 题目介绍  流水线指令计算公式&#xff1a;一条指令总时间max&#xff08;单个指令执行时间&#xff09;*&#xff08;指令数-1&#xff09;  平均故障间隔时间  ICMP协议&#xff1a;传送通信问题相关的消息。 …

【网络】数据在同网段和跨网段通信流程

情景一&#xff1a;同一广播域内&#xff0c;两台主机通信过程&#xff1a; 当NO要和N1通信时&#xff0c;假如N0知道N1的IP但却不知道它的MAC地址&#xff0c;那NO就会发送一个ARP的广播请求<1>&#xff08;里面源IP是NO 目标IP是N1 源MAC是N0 目标MAC是12个F&#xff0…

Learn OpenGL 08 颜色+基础光照+材质+光照贴图

我们在现实生活中看到某一物体的颜色并不是这个物体真正拥有的颜色&#xff0c;而是它所反射的(Reflected)颜色。物体的颜色为物体从一个光源反射各个颜色分量的大小。 创建光照场景 首先需要创建一个光源&#xff0c;因为我们以及有一个立方体数据&#xff0c;我们只需要进行…

LEETCODE3

法一:记忆化递归 int climbStairsRecursive(int n, int* memo) {if (n < 2) {return n;}if (memo[n] > 0) {return memo[n];}memo[n] climbStairsRecursive(n - 1, memo) climbStairsRecursive(n - 2, memo);return memo[n]; }int climbStairs(int n) {int* memo (in…

代码随想录训练营Day21:● 530.二叉搜索树的最小绝对差 ● 501.二叉搜索树中的众数 ● 236. 二叉树的最近公共祖先

530.二叉搜索树的最小绝对差 题目链接 https://leetcode.cn/problems/minimum-absolute-difference-in-bst/description/ 题目描述 思路 遇到在二叉搜索树上求什么最值&#xff0c;求差值之类的&#xff0c;都要思考一下二叉搜索树可是有序的&#xff0c;要利用好这一特点。…

Java 拦截器Interceptor详解

1、拦截器概念 先看一下web请求的流程。 &#xff08;1&#xff09;、当浏览器发送一个请求时&#xff0c;请求到达tomcat容器&#xff0c;tomcat容器会区分静态还是动态资源。 &#xff08;2&#xff09;、动态请求会先经过过滤器链filter&#xff0c;直到全部过滤完成之后&am…

MySQL 事务的原理以及长事务的预防和处置

transaction_isolation 隔离级别 读未提交 读提交 视图是在每个 SQL 语句开始执行的时候创建的 可重复读 视图是在事务启动时创建的&#xff0c;整个事务存在期间都用这个视图 串行化…

3/12/24交换排序、插入排序、选择排序、归并排序

目录 交换排序 冒泡排序 快速排序 插入排序 直接插入排序 选择排序 简单选择排序 堆排序 归并排序 各种排序的时间复杂度、空间复杂度、稳定性和复杂度 快排真题2016 选排真题2022 排序算法分为交换类排序、插入类排序、选择类排序、归并类排序。 交换排序 交换排…

Django 学习笔记(Day1)

「写在前面」 本文为千锋教育 Django 教程的学习笔记。本着自己学习、分享他人的态度&#xff0c;分享学习笔记&#xff0c;希望能对大家有所帮助。 目录 0 课程介绍 1 Django 快速入门 1.1 Django 介绍 1.2 Django 安装 1.3 创建 Django 项目 1.4 运行 Django 项目 1.5 数据迁…

Linux-gdb调试

文章目录 前言查看&#xff08;显示&#xff09;源代码 list/l运行程序run/r打断点b查看断点删除断点打开/关闭断点逐过程 逐语句查看变量常显示continuefinishuntil修改指定变量退出gdb 前言 GDB&#xff0c;即GNU调试器&#xff08;GNU Debugger&#xff09;&#xff0c;是G…

细粒度IP定位参文27(HGNN):Identifying user geolocation(2022年)

[27] F. Zhou, T. Wang, T. Zhong, and G. Trajcevski, “Identifying user geolocation with hierarchical graph neural networks and explainable fusion,” Inf. Fusion, vol. 81, pp. 1–13, 2022. (用层次图、神经网络和可解释的融合来识别用户的地理定位) 论文地址:…

QML 控件添加键盘事件

在QML中&#xff0c;可以使用Keys类型来处理键盘事件。以下是一个简单的示例&#xff0c;演示如何在QML控件中添加键盘事件&#xff1a; import QtQuick 2.12 import QtQuick.Window 2.12Window {visible: truewidth: 640height: 480title: qsTr("Hello World")Recta…

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的常见车型识别系统(Python+PySide6界面+训练代码)

摘要&#xff1a;本文深入探讨了如何应用深度学习技术开发一个先进的常见车型识别系统。该系统核心采用最新的YOLOv8算法&#xff0c;并与早期的YOLOv7、YOLOv6、YOLOv5等版本进行性能比较&#xff0c;主要评估指标包括mAP和F1 Score等。详细解析了YOLOv8的工作机制&#xff0c…

5.Java并发编程—JUC线程池架构

JUC线程池架构 在Java开发中&#xff0c;线程的创建和销毁对系统性能有一定的开销&#xff0c;需要JVM和操作系统的配合完成大量的工作。 JVM对线程的创建和销毁&#xff1a; 线程的创建需要JVM分配内存、初始化线程栈和线程上下文等资源&#xff0c;这些操作会带来一定的时间和…

【基于langchain + streamlit 完整的与文档对话RAG】

本地部署文档问答webdemo 支持 pdf支持 txt支持 doc/docx支持 源文档索引 你的点赞和收藏是我持续分享优质内容的动力哦~ 废话不多说直接看效果 准备 首先创建一个新环境&#xff08;选择性&#xff09; conda create -n chatwithdocs python3.11 conda activate chatwith…

封装的echarts子组件使用watch监听option失效的问题

项目场景&#xff1a; 我在项目里面封装了一个echarts组件&#xff0c;组件接收一个来自外部的option,然后我用了一个watch函数去监听这个option的变化&#xff0c;option变化之后&#xff0c;销毁&#xff0c;然后再新建一个charts表 碎碎念 问题如标题所示&#xff0c;这篇…

自然语言处理: 第十五章RAG(Retrieval Augmented Generation)

论文地址: [2005.11401] Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks (arxiv.org) 代码地址: 可以参考百度文心一言为例子&#xff0c;与本文代码无关 本篇文章主要是介绍Retrieval Augmented Generation下文简称RAG技术的实现原理和代码实现以及大体…