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

溫馨提示×

溫馨提示×

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

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

Vue的Vue.prototype如何使用

發布時間:2022-10-21 17:35:32 來源:億速云 閱讀:249 作者:iii 欄目:開發技術

今天小編給大家分享一下Vue的Vue.prototype如何使用的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

1. 基本示例

在main.js中添加一個變量到 Vue.prototype

Vue.prototype.$appName = 'My App'

這樣 $appName 就在所有的 Vue 實例中可用了,甚至在實例被創建之前就可以

new Vue({
  beforeCreate: function () {
    console.log(this.$appName)
  }
})

控制臺會打印出 My App,就這么簡單!

2. 為實例prototype設置作用域

為什么 appName 要以 開頭?這很重要嗎?這里沒有什么魔法。 開頭? 這很重要嗎? 這里沒有什么魔法。開頭?這很重要嗎?這里沒有什么魔法。 是在 Vue 所有實例中都可用的 property 的一個簡單約定。這樣做會避免和已被定義的數據、方法、計算屬性產生沖突。
如果我們設置:

Vue.prototype.appName = 'My App'

那么如下的代碼輸出什么:

new Vue({
  data: {
    // 啊哦,`appName` 也是一個我們定義的實例 property 名!
    appName: 'The name of some other app'
  },
  beforeCreate: function () {
    console.log(this.appName)
  },
  created: function () {
    console.log(this.appName)
  }
})

日志中會先出現 "My App",然后出現 "The name of some other app",因為 this.appName 在實例被創建之后被 data 覆寫了。我們通過 為實例property設置作用域來避免這種事情發生。你還可以根據你的喜好使用自己的約定,諸如為實例 property 設置作用域來避免這種事情發生。 你還可以根據你的喜好使用自己的約定,諸如為實例property設置作用域來避免這種事情發生。你還可以根據你的喜好使用自己的約定,諸如_appName 或 ΩappName,來避免和插件或未來的插件相沖突。

3. 注冊和使用全局變量

每個組件都是一個vue實例,Vue.prototype加一個變量,只是給每個組件加了一個屬性,這個屬性的值并不具有全局性。
比如以下例子:

// main.js
import Vue from 'vue'
import App from './App'
import router from './router'
import store from './store'

Vue.config.productionTip = false
Vue.prototype.$appName = 'main'

new Vue({
    el: '#app',
    store,
    router,
    components: { App },
    template: '<App/>',
})

// 給所有組件注冊了一個屬性 $appName,賦予初始值 'main' ,所有組件都可以用 this.$appName 訪問此變量;
// 如果組件中沒有賦值,初始值都是'main'
// home.vue
<template>
  <div>
    <div @click="changeName">change name</div>
    <div @click="gotoTest2">goto test2</div>
  </div>
</template>

<script>
export default {
  methods:{
    changeName(){
      this.$appName = "test1"
    },
    gotoTest2(){
      this.$router.push('/about')
    } 
  }
}
</script>
// about.vue
<template>
  <div>
    <div>{{this.$appName}} in test2</div>
  </div>
</template>

點擊 home 中的 change name 再跳轉about,about里面還是顯示 main in test2
如果要實現全局變量的功能,需要把屬性變為引用類型

Vue.prototype.$appName = { name: 'main' }

后面使用 this.$appName.name 改變和引用相應的值
這進入 about 后顯示 test1 in test2

4. 原型方法的上下文

在 JavaScript 中一個原型的方法會獲得該實例的上下文,也就是說可以使用 this 訪問:數據、計算屬性、方法或其它任何定義在實例上的東西。
讓我們將其用在一個名為 $reverseText 的方法上:

 // main.js
Vue.prototype.$reverseText = function (propertyName) {
  this[propertyName] = this[propertyName]
    .split('')
    .reverse()
    .join('')
}
// 相應組件
<script>
export default {
  data() {
    return{
      message: 'Hello'
    }
  },
  created() {
    console.log(this.message) // => "Hello"
    this.$reverseText('message')
    console.log(this.message) // => "olleH"
  }
}
</script>

5. 應用示例

5.1 引入 axios

npm install vue-axios --save

npm install qs.js --save  //它的作用是能把json格式的直接轉成data所需的格式
// mian.js
import Vue from 'vue'
import axios from 'axios'
import qs from 'qs'

Vue.prototype.$axios = axios    //全局注冊,使用方法為:this.$axios
Vue.prototype.qs = qs           //全局注冊,使用方法為:this.qs

// 相應組件
<script>
  export default{
    data(){
      return{
        userId:666,         
        token:'',
      }
    },
    created(){
      this.$axios({
        method:'post',
        url:'api',
        data:this.qs.stringify({    //這里是發送給后臺的數據
          userId:this.userId,
          token:this.token,
        })
      }).then((response) =>{          //這里使用了ES6的語法
        console.log(response)       //請求成功返回的數據
      }).catch((error) =>{
        console.log(error)       //請求失敗返回的數據
      })
    }
  }
</script>

Vue.prototype、Vue.component和Vue.use區別

1、Vue.prototype

在多個地方都需要使用但不想污染全局作用域的情況下,這樣定義,在每個 Vue 實例中都可用。
參考:https://cn.vuejs.org/v2/cookbook/adding-instance-properties.html
$ 表示這是一個在 Vue 所有實例中都可用的屬性
常用于方法、變量等

import echarts from 'echarts'
Vue.prototype.$echarts = echarts

2、vue.component

全局注冊組件,
第一個參數是調用組件時寫的組件名
第二個參數是引入組件時寫的名稱
可用于注冊自定義組件

import myLoading from 'base/loading'
Vue.component('myLoading',myLoading);

3、Vue.use

同樣是全局注冊,和component的區別是接收的參數必須有install方法
常用于注冊第三方插件

import ElementUI from 'element-ui';
Vue.use(ElementUI);

以上就是“Vue的Vue.prototype如何使用”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

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

AI

金华市| 双城市| 庆元县| 铜陵市| 津市市| 曲靖市| 潍坊市| 芜湖市| 柏乡县| 象州县| 五峰| 万盛区| 金秀| 尉氏县| 洛浦县| 上杭县| 镇安县| 博乐市| 安泽县| 阳信县| 蒙阴县| 莱阳市| 石阡县| 贵州省| 大竹县| 鄱阳县| 泰兴市| 舒兰市| 湘西| 慈利县| 长治县| 天峻县| 称多县| 浠水县| 阿城市| 天柱县| 阿克苏市| 通山县| 康马县| 塘沽区| 金湖县|