Vue(数据绑定、el和data多种写法、理解MVVM、数据代理)

news2024/10/6 14:36:47

一、数据绑定

1. vue中有两种数据绑定(通过开发者工具进行查看)

1. 单项绑定(v-bind)数据只能从data流向页面

在输入框中中输入vue实例中的数据没有变化


2. 双向绑定(v-model)数据能从data流向页面,也可以从页面流向数据

在输入框中中输入vue实例中的数据也会变化,同样改变之后如果存在单项数据绑定也会把数据传给的那箱数据绑定的输入框

 

 

2. 备注:

1. 双向绑定一般用在表单类元素
2.v-model:value可以写成v-model,因为v-model默认手机的就是value的值

 

二、el和data的多种写法(学习组件前必学)

 1. el(关联语句)的两种写法

  • new的时候配置el属性

  • 先创建Vue实例,通过(vue实例进行容器指向,这里实例名一般就是vm)vm-$mount('#root')指向el的值

  Vue.config.productionTip = false;
    const vm = new Vue({
      // el: "#root",//关联语句(第一种)

      data: { name: "dragon-fly" },
    });
    vm.$mount("#root"); //关联语句(第二种)比较灵活

 2. data的两种写法:组件必须使用普通函数

  • 对象式

     //1. data的第一种写法:对象式
      data: {
        name: "dragon-fly",
      },
  • 函数式:必须存在返回值(模板接收的就是Vue实例中data函数得到返回值)

      // 2.data的第二种写法:函数式(只有函数名函数式)
      data() {
        //注意此处的对象里面写函数可以删除关键词
        console.log("@@@@@@", this); //this指向实例对象(普通函数式子写法,不可以使用箭头函数)
        return {
          name: "dragon-fly",//必须使用返回值把返回值里内容给容器
        };
        // 此处的函数是vue进行调用
      },

注意:由Vue管理的函数,一定不要写箭头函数,一旦写了箭头函数,this就不再是Vue实例了

三、理解MVVM 

1.什么是MVVM模型?

Vue没有完全遵循MVVM模型

M:模型(model)

data中的数据

V:视图(View)

模板代码

VM:视图模型(ViewMode)

Vue实例

 

 

 

2. MVVM模型特点

  •  data中所有的属性,最后都出现在vm身上

  • vm身上所有属性 及Vue原型上所有属性,在Vue模板中都可以直接使用

        <div id="root">
          <h1>学校名称:{{name}}</h1>
          <h1>学校地址:{{address}}</h1>
          <!-- 除了data还有表达式还包括vm所有属性以及Vue原型上的属性都可用 -->
          <!-- 以下就是vm下的属性以及Vue原型上的属性 -->
          <h1>测试1:{{1+1}}</h1>
          <h1>测试2:{{$options}}</h1>
          <h1>测试3:{{ $emit}}</h1>
          <h1>测试4:{{_c}}</h1>
        </div>
        <script>
          Vue.config.production = false;
    
          const vm = new Vue({
            el: "#root",
            data: {
              name: "北大",
              address: "北京",
            },
          });
    
          console.log(vm);
        </script>

四、数据代理

1. 回顾Object.defineProperty(obj,prop,{descriptor})

定义新属性或修改原有属性

 三个参数:进行处理对象,添加或者修改名,{修改值:包含多个属性}

  • value: 值                                 添加或修改的属性值

  • enumerable:false                控制可枚举(默认是false)

  • writable: true                         控制属性可以被修改(默认是false)

  • configurable: true                 控制属性是否可以被删除(默认是false)

  • get(){}

读取当前define属性时候就会调用getter,返回值就是return值

  • set(){}

修改当前define属性时候就会调用setter,得到传入参数就是具体值

    <script>
      let num = 18; 
      let person = {
        name: "张三",
        sex: "男",
      };
    //此处的getter和setter就使用了数据代理
      Object.defineProperty(person, "age", {
             value: 18,
             enumerable: true, //控制属性是是否可枚举
             writable: true, //控制属性可以被修改(默认是false)
             configurable: true, //控制属性是否可以被删除
        // 高级配置项
        // 当有人读取person的age属性的时候,get函数(gatter)就会被调用,并且返回值就是age的值
        get() {
          console.log("有人读取了age属性");
          return num;
        },
        //当有人修改person的age属性,set函数(setter)就会被调用,且会受到修改的具体值
        set(value) {
          console.log("有人修改age值是" + value);
          num = value;
        },
      });
      
      //   以下两种遍历方式
      //   console.log(Object.keys(person)); //直接将一个对象转换成数组的方法
      //   传统遍历对象
      //for (var key in person) {
      //  console.log("@", person[key]);
      // }
       console.log(person);
    </script>

使用对象新增方法实现的一些东西 

 

 没有使用对象方法直接添加会存在的一些属性

2. 什么是数据代理? 

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

  <script>
      let obj = { x: 100 };
      let obj2 = { y: 200 };
      Object.defineProperty(obj2, "x", {
        get() {
          return obj.x;
        },
        set(value) {
          obj.x = value;
        },
      });
    </script>

 

 

3. Vue中的数据代理 

  • vue中的数据代理:

通过vm对象来代理data对象中属性的操作(读/写)

  • vue中数据代理的好处:

更方便操作data中的数据

  • 基本原理:

通过object.defineProperty()把data对象中所有属性添加到vm上
为每一个添加到vm的属性,都指定getter/setter
在getter/setter内部操作(读/写)data中的属性

 

   <div id="root">
      <h2>学校名称:{{name}}</h2>
      <h2>学校地址:{{address}}</h2>
    </div>
    <script>
      Vue.config.production = false;
      let data = {
        name: "xlf",
        address: "高新一路",
      };
      const vm = new Vue({
        el: "#root",
        data,
      });
    </script>
  • 实现检测getter只需要查看vm.name就可以验证

  • 实现setter就需要使用数据源放在vm实例中的一个属性_data

 

 

 

 

 

 

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

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

相关文章

【Java 数据结构】二叉树的遍历 (递归和非递归实现)

&#x1f389;&#x1f389;&#x1f389;点进来你就是我的人了 博主主页&#xff1a;&#x1f648;&#x1f648;&#x1f648;戳一戳,欢迎大佬指点!人生格言&#xff1a;当你的才华撑不起你的野心的时候,你就应该静下心来学习! 欢迎志同道合的朋友一起加油喔&#x1f9be;&am…

大数据分析查询_Impala介绍_对HDFS_Hbase直接查询_速度快_组成架构_执行原理---大数据之Impala工作笔记0001

官网的地址:Impala (apache.org)https://impala.apache.org/ https://impala.apache.org/ 官网的地址: 首先我们看一下什么是impala,可以看到Impala是cloudera公司,也就是做Hadoop付费版的公司, 提供的,基于Hive的,因为他跟hive共用元数据,meta,他可以提供对HDFS,Hbase的SQL…

好家伙,阿里新产Java性能优化(终极版),涵盖性能优化所有操作

上月公司来了一位大佬&#xff0c;入职不到一周就把公司现有项目的性能优化了一遍&#xff0c;直接给公司节省了一半的成本。 一问情况&#xff0c;才知道这位仁兄也是一路被虐过来的。去年年底被裁&#xff0c;本以为自己技术还行&#xff0c;看了一段时间面经&#xff0c;复…

dB 、dBSPL、dBFS、dBTP

本文整理自&#xff1a;https://corychu.medium.com/%E9%8C%84%E9%9F%B3%E7%AD%86%E8%A8%98-%E6%95%B8%E4%BD%8D%E9%9F%B3%E9%87%8F%E6%A8%99%E6%BA%96-dbfs-dbtp-lufs-c47ca4646b7f 概述&#xff1a;dBFS&#xff08;相对于满刻度的分贝&#xff09;是数字系统中振幅水平的测…

8. 优先队列

8. 优先队列 普通的队列是一种先进先出的数据结构&#xff0c;元素在队列尾追加&#xff0c;而从队列头删除。在某些情况下&#xff0c;我们可能需要找出队列中的最大值或者最小值&#xff0c;例如使用一个队列保存计算机的任务&#xff0c;一般情况下计算机的任务都是有优先级…

element select改成成tree树状下拉

<template><el-select class"jhx-formData-inputRow" ref"configSelect" v-model"orgName" filterable placeholder"请选择":filter-method"filterMethod" clear><el-option :label"orgValue.label&quo…

Redis7中的持久化技术RDB和AOF的详细解释说明

文章目录 前置知识持久化原理RDB持久化RDB优化配置项RDB文件格式RDB持久化过程RDB总结 AOF持久化AOF的工作流程AOF中的rewirte机制rewrite AOF文件格式查看AOF文件 AOF优化配置项 AOFRDB混用纯缓存模式对比和技术选型建议 前置知识 官网关于持久化的说明 Redis 是一个内存数据…

频域抽取FFT(DIF-FFT)的C语言实现

原理 此处以基2频域抽取FFT为例&#xff0c;讲述频域抽取FFT的原理。假设FFT的长度为 N 2 m N2^m N2m&#xff0c;我们将序列 x x x的FFT变换分为以下两个部分&#xff1a; X ( k ) ∑ n 0 N / 2 − 1 x ( n ) W N n k ∑ n N / 2 N − 1 x ( n ) W N n k X(k)\sum_{n0}…

SQL Server存储过程(数据库引擎)使用详解

存储过程&#xff08;数据库引擎&#xff09; 一、背景知识1.1、使用存储过程的好处1.2、存储过程的类型 二、创建存储过程三、修改存储过程四、删除存储过程五、执行存储过程5.1、建议5.2、使用 Transact-SQL执行存储过程 六、授予对存储过程的权限6.1、授予对存储过程的权限6…

院士联合指导+超强专家阵容+丰厚奖金机会,第十二届“麒麟杯”大赛报名正式开启!

当前&#xff0c;开放、协作、共享的开源模式已成为全球软件技术和产业创新的主导&#xff0c;也为信息技术国产自主化提供了强大助力。高校师生作为国产开源建设的主要技术群体之一&#xff0c;是国产开源未来发展的中坚力量。 2023年第十二届“麒麟杯”全国开源应用软件开发…

强制变成Android的形状,iPhone这波更新严重违背祖训

众所周知&#xff0c;苹果每年要开两次发布会。 秋季发布会的主角是新 iPhone &#xff0c;而6月的 WWDC 全球开发者大会则会以软件为主。 WWDC 2023 将于6月5日举行&#xff0c;iOS 17、macOS 14 及新版本 tvOS、WatchOS 都将发布。 同时新的混合现实设备所搭载的 xrOS 也有…

创建Windows 11恢复U盘的两种方法

我们在使用电脑的过程中&#xff0c;无法预知未来会出现什么问题。当您遇到一些严重的系统问题时&#xff0c;您可能需要从故障的计算机中恢复。不幸的是&#xff0c;对于大多数用户来说&#xff0c;这意味着从头开始&#xff0c;因为他们没有提前创建恢复媒体。 虽然Windows 1…

每日学术速递4.20

CV - 计算机视觉 | ML - 机器学习 | RL - 强化学习 | NLP 自然语言处理 Subjects: cs.CV 1.Avatars Grow Legs: Generating Smooth Human Motion from Sparse Tracking Inputs with Diffusion Model(CVPR 2023) 标题&#xff1a;化身长腿&#xff1a;使用扩散模型从稀疏跟踪…

知识蒸馏之自蒸馏【附代码】

知识蒸馏的核心思想就是将大模型的知识传给小模型。 这里的知识通常就是模型所学的数据分布。大模型特点一般是具有非常高的精度&#xff0c;但可能在速度上不行&#xff0c;或者是不易部署&#xff0c;小模型通常是易部署&#xff0c;速度快但精度不如大模型。 因此可以将大…

【程序员面试金典】面试题 02.07. 链表相交

【程序员面试金典】面试题 02.07. 链表相交 题目描述解题思路 题目描述 描述&#xff1a;给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#…

使用Storm proxies动态代理IP浅析影响在线代理IP质量的因素?

影响在线代理IP质量的因素有很多&#xff0c;主要包括以下几个方面&#xff1a; 服务器稳定性&#xff1a;在线代理IP的稳定性和可用性与其所在的服务器质量密切相关。如果服务器配置低、网络不稳定、带宽不足等因素&#xff0c;都可能导致在线代理IP的质量下降。IP地址的稳定性…

【LeetCode】剑指 Offer 66. 构建乘积数组 p312 -- Java Version

题目链接&#xff1a;https://leetcode.cn/problems/gou-jian-cheng-ji-shu-zu-lcof/ 1. 题目介绍&#xff08;66. 构建乘积数组&#xff09; 给定一个数组 A[0,1,…,n-1]&#xff0c;请构建一个数组 B[0,1,…,n-1]&#xff0c;其中 B[i] 的值是数组 A 中除了下标 i 以外的元素…

5.1.1树的定义,基本术语及性质

空树&#xff1a;结点数为0的树 除了根节点外&#xff0c;任何一个结点都有且仅有一个前驱。 子树也可看成一个新的树 所以树其实是一个递归结构 树形逻辑结构的应用 下面我们来看树的基本术语 1.节点之间的关系描述 F是你的兄弟结点&#xff0c;GHIJ就是你的堂兄弟结点。 还…

海信激光电视将亮相中国家电及消费电子博览会 科技定义家庭观影

4月27日至30日,中国家电及消费电子博览会(简称AWE)将在上海新国际博览中心举办。本届AWE强势回归,展馆规模扩大至14个,展示面积超过16万平方米,将吸引超过1200家国内外企业参展,参观人次预计将突破40万。 作为亚洲规模最大的国际家电及消费电子展览会,本届AWE以“智科技,创未来…

设计模式简介及面向对象设计原则

文章目录 前言一、什么是设计模式1、从面向对象谈起2、深入理解面向对象3、软件设计固有的复杂性4、软件设计复杂的根本原因——“变化”5、如何解决复杂性&#xff1f;6、软件设计的目标 二、常用设计模式及分类1、常用的七种设计模式2、设计模式分类 三、面向对象设计原则1、…