从0到1学习Vue框架Day03

6、VM的属性

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>vm的属性</title>
   <script src="../js/vue.js"></script>
</head>
<body>
   <!-- 
      通过Vue实例都可以访问哪些属性?
         Vue实例中的属性很多,有的以$开始,有的以_开始
         所有以$开始的属性,可以看做是公开的属性,这些属性是供程序员使用的。
         所有以_开始的属性,可以看做是私有的属性,这些属性是Vue框架底层使用的。
         通过vm也可以访问Vue实例对象的原型对象上的属性
   -->

   <div id="app">
      <h1>{{msg}}</h1>
   </div>

   <script>
      let dataObj = {
         msg : 'Heool Vue'
      }
      const vm = new Vue({
         el : '#app',
         data : dataObj
      })

      console.log(dataObj.msg);
      console.log(vm.msg);
   </script>
   
</body>
</html>

7、Object.defineProerty()

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>Object.defineProerty()</title>
   <script src="../js/vue.js"></script>
</head>
<body>
   <!-- 
      Object.defineProerty()
      1、这个方法是ES5新增的
      2、作用:给对象新增属性,或者设置对象原有的属性。
      3、object.defineProperty(给哪个对象新增属性, '新增的属性名',{给新增属性设置相关的配置项key:value})
      4、第三个参数是属性相关的配置项,配置项都有哪些?每个配置项的作用是啥?
         value配置项:给属性指定值
         writable配置项:设置该属性的值师范可以被修改
         getter方法 配置项:不需要我们手动调用,当读取属性值的时候,getter方法被自动调用
            getter方法的返回值非常重要,这个返回值就代表这个属性它的值
         setter方法 配置项:不需要我们手动调用的。当修改属性值的时候,setter方法被自动调用
            setter方法上是有一个参数的,这个参数可以接收传过来的值
         注意:当配置项当中有setter和getter的时候,value和writable配置项都不能存在
   -->
   <script>

      let phone = {}
      let temp

      Object.defineProperty(phone, 'color', {
         //value : '灰色',
         //writable : true
         get : function(){
            console.log('getter执行了');
            //return this.color
            return temp
         },
         set : function(val){
            console.log('setter执行了');
            //this.color = val
            temp = val
         }
      })

   </script>



</body>
</html>

8、数据代理机制的实现

html 复制代码
<!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>
   <!-- 
      1、什么是数据代理机制?
         通过访问 代理对象的属性 来间接访问 目标对象的属性
         数据代理机制的实现需要依靠:Object.defineProperty()方法
      2、ES6新特性:
         在对象中的函数/方法:function是可以省略的
   -->

   <script>
      let target = {
         name : 'zhangsan'
      }
      let proxy = {}

      Object.defineProperty(proxy,'name',{
         get(){
            return target.name
         },
         set(val){
            target.name = val
         }
      })
   </script>
</body>
</html>

9、数据代理对属性名的要求

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>数据代理对属性名的要求</title>
   <script src="../js/vue.js"></script>
</head>
<body>
   <!-- 
      1、Vue实例不会给以_和$开始的属性名做数据代理
      2、为什么?
         如果允许给_或$开始的属性名做数据代理的话
         vm这个Vue实例上可能会出现_xxx或$xxx属性
         而这个属性名可能会和Vue框架自身的属性名冲突
      3、在Vue当中,给data对象的属性名命名的时候,不能以_或$开始
   -->

   <div id="app">
      <h1>{{msg}}</h1>
   </div>

   <script>
      const vm = new Vue({
         el : '#app',
         data : {
            msg : 'bjpowernode',
            $name : 'zhangsan',
            _age : 20
         }
      })
   </script>
</body>
</html>

10、手写Vue框架数据代理的实现

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>数据代理对属性名的要求</title>
   <script src="../js/vue.js"></script>
</head>
<body>
   <!-- 
      1、Vue实例不会给以_和$开始的属性名做数据代理
      2、为什么?
         如果允许给_或$开始的属性名做数据代理的话
         vm这个Vue实例上可能会出现_xxx或$xxx属性
         而这个属性名可能会和Vue框架自身的属性名冲突
      3、在Vue当中,给data对象的属性名命名的时候,不能以_或$开始
   -->

   <div id="app">
      <h1>{{msg}}</h1>
   </div>

   <script>
      const vm = new Vue({
         el : '#app',
         data : {
            msg : 'bjpowernode',
            $name : 'zhangsan',
            _age : 20
         }
      })
   </script>
</body>
</html>
相关推荐
星幻元宇VR3 分钟前
VR环保学习机|科技助力绿色教育新模式
大数据·科技·学习·安全·vr·虚拟现实
猪八宅百炼成仙5 分钟前
解决Vue项目中scrollIntoView导致的布局异常问题
前端
miss14 分钟前
Vue2 → Vue3 深度对比:8 大核心优化,性能提升 2 倍
前端·vue.js·架构
沫离痕27 分钟前
AI机器人客服-Dify接入
开发语言·javascript·ecmascript
_一只小QQ34 分钟前
软考中级第二节
学习
绝世唐门三哥1 小时前
React---数组浅拷贝之slice的使用
前端·reactjs
傅里叶1 小时前
Flutter开发的app,实现Google 登录
前端·flutter
天理小学渣1 小时前
JavaScript_基础教程_自学笔记
开发语言·javascript·笔记
angerdream1 小时前
最新版vue3+TypeScript开发入门到实战教程之生命周期函数
javascript·vue.js
胖橘1 小时前
适用于Vue3的高集成度文件预览组件,支持多种类型的文件
前端·vue.js·开源