91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue指令的三要素有哪些

發布時間:2022-03-23 11:06:21 來源:億速云 閱讀:183 作者:小新 欄目:MySQL數據庫

這篇文章給大家分享的是有關vue指令的三要素有哪些的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

vue指令的三要素是響應式、模板引擎和渲染。響應式是指當更新或者增加數據時,頁面會有響應,重新渲染對應的數據;模板本質上是字符串,模板最終轉換成js代碼。

本文操作環境:windows10系統、Vue2.9.6版,DELL G3電腦。

vue指令的三要素是什么

veu中的三要素

  • 響應式:vue如何監聽到 data 每個屬性變化?

  • 模板引擎:vue的模板如何被解析,指令如何處理?

  • 渲染:vue 的模板如何被渲染成 html?以及渲染過程

vue 如何實現是響應式

Object.defineProperty

模擬

1) 什么是響應式

修改 data 屬性之后, vue 立刻監聽

data 屬性被代理到 vm 上

2) Object.defineProperty

語法:

Object.defineProperty(obj, prop, descriptor)

參數說明:

  • obj:必需。目標對象

  • prop:必需。需定義或修改的屬性的名字

  • descriptor:必需。目標屬性所擁有的特性

基礎

var obj = {
  name: 'zhangsan',
  age: 25
}
 
console.log(obj.name); // 獲取屬性的時候,如何監聽
obj.age = 26; // 賦值屬性的時候,如何監聽

我們用defineProperty方法實現上面的操作:如下

var obj = {}
 
var name = 'zhangsan'
 
Object.defineProperty(obj, "name", {
  get: function () {
    console.log('get');
    return name;
  },
  set: function (newVal) {
    console.log('set');
    name = newVal;
  }
});
 
console.log(obj.name); // 可以監聽到
obj.name = 'lisi'; // 可以監聽到

使用defineProperty我們就可以監聽到數據變化了。其中這個也是 vue 做響應工做核心的方法了。

3) 模擬

var mv = {}
 
var data = {
  price: 100,
  name: 'zhangsan'
}
 
var key, value;
for (key in data) {
 
  // 命中閉包。新建一個函數,保證 key 的獨立的作用域
  (function (key) {
Object.defineProperty(mv, key, {
  get: function () {
    console.log('get');
    return data[key];
  },
  set: function (newVal) {
    console.log('set');
    data[key] = newVal
  }
})
  })(key);
}

vue的模板如何被解析

模板是什么

render 函數

render 函數 與 vdom

1) 模板是什么

本質:字符串

有邏輯,如 v-if v-for等

與 html 格式很像,但有很大的區別

最終還要轉換成 html 來顯示

模板最終必須轉換成 JS 代碼, 因為:

有邏輯(v-if v-for),必須用 JS 才能實現( 圖靈完備)

轉換為 html 渲染頁面,必須用 JS 才能實現

因此,模板最重要轉換成一個 JS 函數

基礎事例

 <div id="app">
    <div>
      <input v-model="title">
      <button v-on:click="add">submit</button>
    </div>
    <ul>
      <li v-for="item in list">{{item}}</li>
    </ul>
  </div>

以上就是一個模板。

感謝各位的閱讀!關于“vue指令的三要素有哪些”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

梧州市| 新和县| 东莞市| 天等县| 建始县| 额济纳旗| 洪洞县| 黔东| 太仓市| 永昌县| 安康市| 枞阳县| 广水市| 乌鲁木齐市| 五河县| 铜川市| 宁夏| 桃江县| 白朗县| 宝坻区| 龙泉市| 湖口县| 南平市| 淮阳县| 阳东县| 邹城市| 随州市| 龙井市| 化德县| 墨玉县| 武汉市| 开化县| 琼中| 崇阳县| 黔西| 即墨市| 荣昌县| 同江市| 梅州市| 宁河县| 嘉兴市|