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

溫馨提示×

溫馨提示×

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

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

Vue中怎么定義數據

發布時間:2021-09-24 14:41:20 來源:億速云 閱讀:227 作者:小新 欄目:開發技術

小編給大家分享一下Vue中怎么定義數據,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

在Vue中,按照是否需要雙向數據綁定,可以將變量分為兩種:

一種是需要被Vue的數據劫持,將data的變化實時響應到view上

只要data只能夠的msg變化, template中綁定的msg會實時響應

<template>
  <div>{{msg}}</div>
</template>

<script>
export default {
  data() {
    msg: "" 
  }
};
</script>

還有一種不需要被Vue數據劫持:

僅在script中生效,在template中沒有使用,不需要數據劫持

name僅在concatName函數中生效,那么將其作為局部變量定義即可

age在函數getAge和concatName中都需要使用,作為局部變量使用不合適,那么可以將其作用域提升,方便在多個地方使用

<script>
const age = 'bar'
export default {
  methods: {
    getAge() {
      return age
    },
    concatName() {
      let name = 'nordon'
      reutrn `name:${name}, age: ${age} `
    }
  },
};
</script>

僅僅是在template中作為渲染數據使用,自定義之后便不會在后續的操作中對其修改,這種數據如果使用Vue對其數據劫持會浪費一些性能

<template>
  <div v-for="item in arr">{{item.name}}</div>
</template>

<script>
const arr = Object.freeze([{
  name: 'nordon',
  age: 18
}])
export default {
  data() {
    return {
      arr
    }
  }
};
</script>

使用Object.freeze將不需要數據劫持的數據進行凍結操作,在Vue中遞歸遍歷數據進行數據劫持的時候便不會對其進行數據劫持,特別對于大量的表格類的數據性能提升會顯著一些

可以從Vue源碼中看到,為何使用了Object.freeze對數據處理之后,便不會再進行數據劫持

function defineReactive (obj, key) {
  // 刪除無關代碼 只保留了判斷條件
  const property = Object.getOwnPropertyDescriptor(obj, key)
  if (property && property.configurable === false) {
    return
  }
}

以上是“Vue中怎么定義數據”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

vue
AI

资兴市| 六盘水市| 济宁市| 闽清县| 泰宁县| 沐川县| 乐业县| 茌平县| 遂昌县| 罗城| 米泉市| 蕲春县| 遵义市| 乌拉特中旗| 大渡口区| 临邑县| 新竹县| 潍坊市| 越西县| 黎城县| 庆元县| 邓州市| 平乐县| 正安县| 崇信县| 青海省| 基隆市| 乌鲁木齐县| 郑州市| 余干县| 黑河市| 武安市| 西安市| 宝兴县| 乐安县| 敖汉旗| 姚安县| 福州市| 新竹市| 松原市| 图木舒克市|