千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Vue的雙向數據綁定原理是什么

Vue的雙向數據綁定原理是什么

來源:千鋒教育
發(fā)布人:qyf
時間: 2022-09-15 16:58:38 1663232318

Vue的雙向數據綁定原理是什么

  在Vue2.x中,雙向數據綁定是通過 數據劫持 結合 發(fā)布訂閱模式的方式來實現的,也就是說數據和視圖同步,數據發(fā)生變化,視圖跟著變化,視圖變化,數據也隨之發(fā)生改變。核心:關于VUE雙向數據綁定,其核心是 Object.defineProperty()方法。

  Vue3.x則是用ES6的語法Proxy對象來實現的。

  Object.defineProperty()的缺點:

  1. 只能監(jiān)聽對象(Object),不能監(jiān)聽數組的變化,無法觸發(fā)push, pop, shift, unshift,splice, sort, reverse。

  2. 必須遍歷對象的每個屬性

  3. 只能劫持當前對象屬性,如果想深度劫持,必須深層遍歷嵌套的對象。

  Proxy的優(yōu)點:

  4. Proxy 可以直接監(jiān)聽對象而非屬性。

  5. Proxy 可以直接監(jiān)聽數組的變化。

  6. Proxy 有多達 13 種攔截方法,不限于 apply、ownKeys、deleteProperty、has 等等是 Object.defineProperty 不具備的。

  7. Proxy 返回的是一個新對象,我們可以只操作新的對象達到目的,而 Object.defineProperty 只能遍歷對象屬性直接修改。

  8. Proxy 作為新標準將受到瀏覽器廠商重點持續(xù)的性能優(yōu)化,也就是傳說中的新標準的性能紅利。

  let arr = [];

  let proxy = new Proxy(arr, {

  get: function(obj, prop){

  return obj[prop];

  },

  set: function(obj, prop, value){

  obj[prop] = value; //可以被監(jiān)聽到變化

  return true;

  }

  });

  setTimeout(()=>{

  proxy.push(1);

  }, 2000)

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
開班信息
北京校區(qū)
  • 北京校區(qū)
  • 大連校區(qū)
  • 廣州校區(qū)
  • 成都校區(qū)
  • 杭州校區(qū)
  • 長沙校區(qū)
  • 合肥校區(qū)
  • 南京校區(qū)
  • 上海校區(qū)
  • 深圳校區(qū)
  • 武漢校區(qū)
  • 鄭州校區(qū)
  • 西安校區(qū)
  • 青島校區(qū)
  • 重慶校區(qū)
  • 太原校區(qū)
  • 沈陽校區(qū)
  • 南昌校區(qū)
  • 哈爾濱校區(qū)
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
青草久久久国产免费观看视频 | 亚洲一区二区人妖: | 日本中文字幕永久免费 | 一本一久本久a久久精品 | 在线观看亚洲精品不卡 | 亚洲精品视频在线观看播放 |