zoukankan      html  css  js  c++  java
  • 2019-5-5学习心得

    对象的一个方法
    例如:

    const obj = {
    ["func"](a,b){
    }
    }等价于
    var obj={
    func:function(a,b){}
    }


    其中方括号内是个变量的形式更多见
    因为原来es5里面属性名不能是变量,只能先定义一个对象,再给对象的属性赋值,es6可以直接定义一个变量做属性名

    vue组件中的data必须是函数

    类比引用数据类型
    Object是引用数据类型,如果不用function 返回,每个组件的data 都是内存的同一个地址,一个数据改变了其他也改变了;

    javascipt只有函数构成作用域(注意理解作用域,只有函数的{}构成作用域,对象的{}以及 if(){}都不构成作用域),data是一个函数时,每个组件实例都有自己的作用域,每个实例相互独立,不会相互影响

    const MyComponent = function() {};
    MyComponent.prototype.data = {
        a: 1,
        b: 2,
    }
    const component1 = new MyComponent();
    const component2 = new MyComponent();
    
    component1.data.a === component2.data.a; // true;
    component1.data.b = 5;
    component2.data.b // 5
    

      

    如果两个实例同时引用一个对象,那么当你修改其中一个属性的时候,另外一个实例也会跟着改;

    两个实例应该有自己各自的域才对,需要通过下面的方法来进行处理

    const MyComponent = function() {
        this.data = this.data();
    };
    MyComponent.prototype.data = function() {
        return {
            a: 1,
            b: 2,
        }
    };
    

      这样么一个实例的data属性都是独立的,不会相互影响了.
    所以,你现在知道为什么vue组件的data必须是函数了吧。这都是因为js本身的特性带来的,跟vue本身设计无关。其实vue不应该把这个方法名取为data(),应该叫setData或其他更容易理解的方法名。

  • 相关阅读:
    jQuerychicun
    css3动画
    app开发,H5+CSS3页面布局小tips
    函数基础
    函数
    冒泡排序
    关于Vue+iview的前端简单的导入数据(excel)
    关于Vue+iview的简单下拉框滚动加载
    ES6中set的用法回顾
    百度地图api设置点的自定义图标不显示
  • 原文地址:https://www.cnblogs.com/calvin-dong/p/10815512.html
Copyright © 2011-2022 走看看