Vue——认识day02

news2024/12/26 12:04:56

        此处接上一篇文章Vue——初识Vue开始,欢迎大家。

目录

1.MVVM模型

2.Object.defineproperty方法

3.数据代理简介

4.Vue中的数据代理

总结



1.MVVM模型

        MVVM模型是一种软件架构模式,用于将用户界面(View),业务逻辑(Model)和视图模型(ViewModel)之间的关系解耦。MVVM的目标是实现用户界面的可复用性和可维护性。

        在MVVM模型中,用户界面(View)负责显示数据和接收用户操作。它通过数据绑定与视图模型(ViewModel)进行交互,以获取和更新数据。视图模型(ViewModel)是用户界面(View)的抽象,它包含了与用户界面相关的业务逻辑和数据。视图模型通过数据绑定从模型(Model)中获取数据,并将数据在用户界面上进行展示。

        模型(Model)是业务数据和业务逻辑的抽象。它负责数据的获取和存储,并包含了与数据相关的操作和验证逻辑。模型可以与外部数据源(例如数据库或网络)进行交互。

        MVVM模型的核心概念是数据绑定,它将数据和用户界面之间的关系自动化。数据绑定允许视图模型将数据绑定到视图上,并且在数据发生变化时自动更新视图。这种自动更新减少了开发人员的工作量,并提高了用户界面的可维护性。

        总结来说,data中的所有属性,最后都会交给vm。vm中的所有属性(包括vue自带的)在vue模版(view)中都可以直接使用。


2.Object.defineproperty方法

        具体讲解都放置于代码注释之中了。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>介绍Object.defineproperty方法</title>

</head>
<body>
    <script type="text/javascript">

        let number = 20

        let person = {
            name:'WJJ',
            // 这样写就可以遍历
            // age:20,
            sex:'女'
        }
// 参数解析:第一个参数是 要定义属性的对象。
//          第二个参数是 要定义或修改的属性的名称
//          第三个属性是一个对象,里面写一些(配置)属性
        // 1.使用这中方法添加的属性不参与枚举
        // 2.使用这种方法添加的属性在页面无法修改
        // 3.使用这种方法添加的属性在页面无法被删除
        Object.defineProperty(person,'age',{
            // //value:18,
            // value:number,
            // // 开启这个为true,就可以让这个添加的属性加入枚举
            // enumerable:true,
            // // 开启这个为true,就可以让这个添加的属性在页面可修改
            // writable:true,
            // // 开启这个为true,就可以让这个添加的属性在页面可删除
            // configurable:true,

            // 当有人读取person中的age的数据时
            // get函数(getter)就会被调用,且返回值就是age的值
            get(){
                return number
            },

            // 当有人修改person中的age的数据时
            // set函数(setter)就会被调用,且会收到修改后的值
            set(value){
                number = value
                console.log('修改成功:',value)

            }
        })
        console.log(person)
        // 这里就可以发现并没有找到age这个属性
        console.log(Object.keys(person))
        for(let key in person){
            console.log('值的数据为:',person[key])
        }

    </script>
</body>
</html>


3.数据代理简介

        数据代理:通过一个对象代理对另一个对象中属性的操作(读、写)

如下示例代码所示:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>什么是数据代理</title>
</head>
<body>
    <script type="text/javascript">
    // 数据代理:通过一个对象代理对
    // 另一个对象中属性的操作(读、写)
    let obj = {a:100}
    let objP = {b:200}

    Object.defineProperty(objP,'a',{
        get(){
            return obj.a
        },
        set(value){
            obj.a = value
        }
    })
    </script>

</body>
</html>

4.Vue中的数据代理

        在Vue中,数据代理是指将data对象中的所有属性代理到Vue实例上,使得我们可以通过实例访问到data对象中的属性。

        Vue实例的data选项中定义的属性会被Vue代理到实例上,这样我们可以直接通过实例访问这些属性,而不需要通过data对象来访问。这样做的好处是可以简化代码,提高代码的可读性和可维护性。

        通过数据代理,我们可以在Vue实例中直接访问data中的属性,而无需使用this.data来访问。例如,如果在data中定义了一个属性name,我们可以直接通过this.name来访问该属性。

        当我们在Vue实例中访问data中的属性时,Vue会自动进行数据劫持,即在访问属性时会触发get拦截器,从而实现属性的响应式。

        需要注意的是,Vue只会对data中已经存在的属性进行代理,而不会代理动态添加的属性。如果需要代理动态添加的属性,可以使用Vue.set或this.$set方法。

下面是一个简单的示例:

var vm = new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!'
  }
});

console.log(vm.message); // 输出:Hello Vue!

        在上述示例中,我们将data对象中的属性message代理到了Vue实例vm上,可以直接通过vm.message访问该属性。

        下面的来自尚硅谷的图示:

总结

一个字较为ez,祝大家学习愉快!!!

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

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

相关文章

牛客周赛 Round 35 (A~G)

本次A~D较为简单&#xff0c;E是一道很好的构造题&#xff0c;FG主要就是考察组合数和约数个数 A.小红的字符串切割 思路 &#xff1a;签到题 void solve() {string s;cin>>s;int lens.size();cout<<s.substr(0,len/2)<<endl<<s.substr(len/2); }B.小…

搭建面向切面编程项目

此项目在整合Mybatis基础上修改&#xff0c;可参考主页的整合Mybatis文章 注解版本 第一步 引入maven坐标 <!-- 切面编程所需jar包--><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId>…

Chapter 04 Vue指令(下)

欢迎大家订阅【Vue2Vue3】入门到实践 专栏&#xff0c;开启你的 Vue 学习之旅&#xff01; 文章目录 前言一、指令修饰符二、v-bind对于样式操作的增强三、v-model应用于表单元素 前言 在 Vue.js 中&#xff0c;指令是带有 v- 前缀的特殊属性&#xff0c;不同属性对应不同的功…

[原理理解] Swin Transformer相对位置编码理解

文章目录 简述相对位置编码的意义直观理解注意力相对位置获取必要性当前位置初步获取利用广播机制获取相对位置索引XY获取最后相对位置1获取最后相对位置2最终的相对位置值嵌入 简述 在看Swin Transformer的时候&#xff0c;一开始在相对位置编码这一块的理解上卡壳了挺久&…

27 Combobox组件

Tkinter ttk.Combobox 组件使用指南 ttk.Combobox 是 Tkinter 的一个高级控件&#xff0c;它结合了文本框和下拉列表的功能&#xff0c;允许用户从预定义的选项列表中选择一个值。ttk 模块是 Tkinter 的一个扩展&#xff0c;提供了更现代的控件外观和行为。以下是对 ttk.Combo…

hyperf json-rpc

安装 安装docker hyperf 安装 hyperf-rpc-server-v8 &#xff08;服务端&#xff09; docker run --name hyperf-rpc-server-v8 \ -v /www/docker/hyperf-rpc-server:/data/project \ -w /data/project \ -p 9508:9501 -it \ --privileged -u root \ --entrypoint /bin/sh \…

港口行业大数据BI建设方案(24页PPT)

方案简介&#xff1a; 港口行业BI建设方案旨在通过数据整合、分析、可视化及智能化决策支持等手段&#xff0c;提升港口运营效率与管理水平。它的建设实施有利推动港口数字化转型、是提升竞争力的关键举措。通过构建高效、智能的BI系统&#xff0c;港口企业能够实现对运营数据…

软设例题—哈夫曼树

哈夫曼树基本概念&#xff1a; 叶子结点的路径长度&#xff1a;结点到根的分支数量 树的路径长度&#xff1a;所有叶子结点路径长度之和 权&#xff1a;叶子结点的数值 叶子结点的带权路径长度&#xff1a;权重*路径 树的带权路径长度&#xff1a;所有叶子结点带权路径之和…

# Windows 系统安装 virtualbox/vmware 虚拟机教程

Windows 系统安装 virtualbox/vmware虚拟机教程 段子手-168 2024-8-28 一、virtualbox/vmware 简介 1、VirtualBox VirtualBox 是开源的、免费虚拟机软件。VirtualBox 是由德国 Innotek 公司开发&#xff0c;由 Sun Microsystems 公司出品的软件&#xff0c;号称是最强的免…

前端学习笔记-Web APIs篇-01

变量声明 变量声明有三个 var let 和 const 建议&#xff1a; const 优先&#xff0c;尽量使用const&#xff0c; 原因是&#xff1a; const 语义化更好很多变量我们声明的时候就知道他不会被更改了&#xff0c;那为什么不用 const呢&#xff1f;实际开发中也是&#xff0c…

如何使用ssm实现基于ssm的软考系统+vue

TOC ssm321基于ssm的软考系统vue 系统概述 1.1 研究背景 如今互联网高速发展&#xff0c;网络遍布全球&#xff0c;通过互联网发布的消息能快而方便的传播到世界每个角落&#xff0c;并且互联网上能传播的信息也很广&#xff0c;比如文字、图片、声音、视频等。从而&#x…

11 索引

目录 没有索引&#xff0c;可能会有什么问题认识磁盘 1. 没有索引&#xff0c;可能会有什么问题 所以&#xff1a;提高数据库的性能&#xff0c;索引是物美价廉的东西。不用加内存&#xff0c;不用改程序&#xff0c;不用调sql&#xff0c;只要执行正确的create index&#x…

Python 数据分析笔记— Numpy 基本操作

文章目录 学习内容&#xff1a;一、什么是数组、矩阵二、创建与访问数组三、矩阵基本操作 学习内容&#xff1a; 一、什么是数组、矩阵 数组&#xff08;Array&#xff09;&#xff1a;是有序的元素序列&#xff0c;可以是一维、二维、多维。 array1 [1,2,3] 或[a, b, c, d…

Littorine生物合成糖基转移酶和酰基转移酶-文献精读39

Functional genomics analysis reveals two novel genes required for littorine biosynthesis 功能基因组学分析揭示了两个Littorine生物合成所需的新基因&#xff0c;基因组挖掘很有效果~ 摘要 一些茄科药用植物能够生产药用莨菪烷类生物碱&#xff08;TAs&#xff09;&am…

MYSQL:简述对B树和B+树的认识

MySQL的索引使用B树结构。 1、B树 在说B树之前&#xff0c;先说说B树&#xff0c;B树是一个多路平衡查找树&#xff0c;相较于普通的二叉树&#xff0c;不会发生极度不平衡的状况&#xff0c;同时也是多路的。 B树的特点是&#xff1a;他会将数据也保存在非叶子节点。而这个…

样本存储需要注意的事项

在实验室和研究机构中&#xff0c;有一些样本是非常重要且需要特殊保护的&#xff0c;这些样本可能包括珍贵的细胞培养物、生物医学样本、药物试剂等等&#xff0c;为了保证这些样本的质量和完整性&#xff0c;采取一些特殊的措施来进行存储管理非常重要。 一旦这些珍贵样本出…

Undertow 性能、配置

一、性能对比 Tomcat vs Jetty vs Undertow性能对比,详细文章: Tomcat vs Jetty vs Undertow性能对比-腾讯云开发者社区-腾讯云 (tencent.com)https://cloud.tencent.com/developer/article/1699803压测指标的结果: 吞吐量:Undertow > Jetty > Tomcat响应时间&…

World of Warcraft [CLASSIC][80][Shushia] Call to Arms: Alterac Valley

Alterac Valley 奥特兰克山谷 明明能拿7000-9000荣誉&#xff0c;白送的大战场&#xff0c;废材太多&#xff0c;看不下去了&#xff0c;动不动就杀女人&#xff0c;丢墓地&#xff0c;最终拿什么3000荣誉&#xff0c;也不知道脑子装啥。 我们55级的时候就能把联盟打的不要不要…

物料类型 UNBW 和 NLAG

业务示例 公司的广告部门负责采购广告业务并承担相应的费用。这些宣传册不应该存储在广告部门&#xff1b;而应该存储在物料仓库中。并且需要基于数量而不是金额进行库存管理。因此这些物料的物料类型为未评估物料(UNBW)。 物料类型 UNBW 物料类型UNBW表示未评估物料。可以通…

第20讲 动画讲解轻松学会STM32的PWM

来源&#xff1a;【STM32】动画讲解轻松学会STM32的PWM_哔哩哔哩_bilibili 基本概念 周期/频率 计算公式&#xff1a;PWM周期1个高电平用时1个低电平用时 PWM的频率1/周期 如图所示此时周期为1ms&#xff0c;即1s内存在1000组这样的高低电平&#xff0c;PWM的频率为1000hz。…