动态DOM操作—数据双向绑定

一个简易的需求,实现动态DOM更新。

后台获取设备数据(ID、name、content...),初始化页面加载完,后台会实时推送设备的content(一张图片,设备当前回显)。前台就要去更新页面的数据,不使用框架很难去查找具体的设备DOM节点在哪,进行更新。在了解了Vue的数据双向绑定原理后,不使用框架可以简易实现该需求。

了解Proxy 值set拦截,快速了解基本原理。


//自定义辅助工具方法,对一些错误可自己处理。

{

    createDom: createDom,      // 创建节点

    addClass: addClass,        // 添加class

    addValue: addValue,        // 添加文本值

    addAttr: addAttr            // 添加或更新属性

  };

1.实现需求,动态DOM数据渲染。
效果实现

function monitor_1024(obj) {

  var deviceInfo = {

    deviceId: obj.deviceId,

    deviceName: obj.deviceName,

    content: obj.content,

  };

  let _this = this;

  // 拦截属性的值更新操作、DOM自动更新的核心

  // 可自定义字段检查过滤

  this.proxyInfo = new Proxy(deviceInfo, {

    get(target, prop) {

      if (prop in target) {

        return Reflect.get(target, prop);

      } else {

        throw new ReferenceError("Property  " + prop + " does not exits");

      }

    },

    set(target, prop, value) {

      if (prop == "content") {

      // content 值发生变化时,拦截,进行DOM更新

        let title = $(_this.item)

          .find(".main")

          .find(".content")

          .find("img");

        util.addAttr(title[0], value);

      }

      Reflect.set(target, prop, value);

    }

  });

  // 定义各属性dom自动更新

  var item = util.createDom("div");

  util.addClass(item, "itemInfo");

  var header = this.createHeader();

  var body = this.createBody();

  item.appendChild(header);

  item.appendChild(body);

  // 渲染到DOM

  $("#monitorInfo").append(item);

  // 保存DOM对象

  this.item = item;

}

// 创建头部

monitor_1024.prototype.createHeader = function() {

  // 创建头部

  // ...

  return header;

};

monitor_1024.prototype.createBody = function() {

  // 创建内容部分

  // ...

  return main;

};

// 获取后台接口数据

let obj = [

  {

    deviceId:'0101',

    deviceName:'test',

    content:'**/datas/001.png'

  },{

    deviceId:'1101',

    deviceName:'test',

    content:'**/datas/101.png'

  }

]

// 用于保存每个设备的实例,

var map = new Map();

for(item of obj){

let p = new monitor_1024(item);

//保存对象示例,以ID为键值

map.set(item.deviceId,p);

}

初始化数据完成,基本功能完成了,下次的数据更新也只是调用。

2.后台数据推送了

页面无刷新,数据更新


// 这是新的数据

let obj = [

{

  deviceId:'0101',

  deviceName:'test',

  content:'**/datas/011.png'

},{

  deviceId:'1101',

  deviceName:'test',

  content:'**/datas/101.png'

}

]

// 数据更新

for(item of obj){

  if(map.has(item.deviceId)){

    // proxyInfo 是Proxy的实例查看文章前连接,了解Proxy

    map.get(item.deviceId).proxyInfo.content = item.content;

  }

}

功能完成了,实现数据的双向绑定。

ps:有什么问题,请大家多多指教。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,657评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,889评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,057评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,509评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,562评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,443评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,251评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,129评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,561评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,779评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,902评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,621评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,220评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,838评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,971评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,025评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,843评论 2 354

推荐阅读更多精彩内容