实现一个简单的类 Vue 框架(一) —— 数据的绑定之简单粗暴方法

Vue框架的核心概念一个是数据绑定,一个是虚拟Dom;先实现数据绑定。本框架命名为Sue。旨在模拟实现一个类Vue

一.最简单粗暴的数据绑定方法

要点:1.call的使用。2.for in 

代码:

/* 最简单粗暴的数据绑定 */
function Sue(options) {
    initData(this,options)
    if (typeof options.ready === 'function') {
        options.ready.call(this)
    }
}

function initData (vm,options) {
    var data = options.data;
    data = typeof data === 'function' ? data() : data || {};
    for (var key in data) {
        if (data.hasOwnProperty(key)) {
            vm[key] = data[key]
        }
    }
}

new Sue({
    data(){
        return {
            name:'ssx',
            age:18
        }
    },
    ready(){
        console.log("name",this.name);
        console.log("age",this.age);
    }
})

存在的问题:数据修改后不能监听到。所以需要有一种机制来实现数据修改可以监听到。看下篇文章:Vue数据监听的方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值