广告
返回顶部
首页 > 资讯 > 精选 >Vue中Vue.prototype怎么用
  • 548
分享到

Vue中Vue.prototype怎么用

2023-06-20 13:06:24 548人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关Vue中Vue.prototype怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 基本示例在main.js中添加一个变量到 Vue.prototypeVue.prot

这篇文章将为大家详细讲解有关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.jsimport Vue from 'vue'import App from './App'import router from './router'import store from './store'Vue.config.productionTip = falseVue.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.jsVue.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 --savenpm install qs.js --save  //它的作用是能把JSON格式的直接转成data所需的格式
// mian.jsimport Vue from 'vue'import axios from 'axios'import qs from 'qs'Vue.prototype.$axios = axios    //全局注册,使用方法为:this.$axiosVue.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怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: Vue中Vue.prototype怎么用

本文链接: https://www.lsjlt.com/news/297135.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue中Vue.prototype怎么用
    这篇文章将为大家详细讲解有关Vue中Vue.prototype怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 基本示例在main.js中添加一个变量到 Vue.prototypeVue.prot...
    99+
    2023-06-20
  • Vue中Vue.prototype如何用
    这篇文章主要讲解了“Vue中Vue.prototype如何用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中Vue.prototype如何用”吧!1. 基本示例在main.js中添加一...
    99+
    2023-07-04
  • Vue中 Vue.prototype使用详解
    目录1. 基本示例2. 为实例prototype设置作用域3. 注册和使用全局变量4. 原型方法的上下文5. 应用示例5.1 引入 axiosVue.prototype、Vue.co...
    99+
    2022-11-12
  • vue中vue-router怎么使用
    这篇文章主要介绍“vue中vue-router怎么使用”,在日常操作中,相信很多人在vue中vue-router怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中vue-router怎么使用”的疑...
    99+
    2023-06-30
  • vue中replace怎么用
    这篇文章给大家分享的是有关vue中replace怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在vue中,replace用于匹配指定的字符串并替换,或者替换跳转时的记录,语法为“str.replace(re...
    99+
    2023-06-29
  • vue中router怎么用
    这篇文章主要介绍vue中router怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!路由,其实就是指向的意思,当我点击页面上的home按钮时,页面中就要显示home的内容,如果点...
    99+
    2022-10-19
  • Vue中Weex怎么用
    这篇文章主要介绍了Vue中Weex怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、开发环境在这个 Weex app 开发中,我的开发...
    99+
    2022-10-19
  • vue中indexof怎么用
    小编给大家分享一下vue中indexof怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在vue中,indexof()可用来...
    99+
    2022-10-19
  • Vue中props怎么用
    这篇文章主要为大家展示了“Vue中props怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue中props怎么用”这篇文章吧。前言:在Vue中通过props,可以将原本孤立的组件串联起来...
    99+
    2023-06-21
  • vue中ref怎么用
    vue中ref的用法有三种,分别是:1.ref加在普通的元素上,用this.ref.name获取dom元素;2.ref加在子组件上,用this.ref.name 获取组件实例,可以使用组件的所有方法;3.利用v-for和ref获取一组数组或...
    99+
    2022-10-06
  • Vue中bus怎么用
    这篇文章主要介绍了Vue中bus怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。vue总线机制(bus)vue中非父子组件之间通信除了使用vuex,也可以通过bus总线,...
    99+
    2023-06-14
  • vue中$on怎么用
    这篇文章给大家分享的是有关vue中$on怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在vue中,“$on”用于监听当前实例上的自定义事件,事件可以由“vm.$emit”触发,回调函数会接收所有传入事件触发...
    99+
    2023-06-29
  • vue中$emit怎么用
    这篇文章主要为大家展示了“vue中$emit怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中$emit怎么用”这篇文章吧。在vue中,“$emit”用于触发当前实例上的事件,附近参数...
    99+
    2023-06-29
  • vue中vuex怎么使用
    这篇文章将为大家详细讲解有关vue中vuex怎么使用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。vue概念:vuex 是 Vue 配套的 公共数据管理工具,它可以把一些...
    99+
    2022-10-19
  • vue中组件怎么用
    这篇文章主要为大家展示了“vue中组件怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中组件怎么用”这篇文章吧。前言组件是Vue.js最强大的功能之一...
    99+
    2022-10-19
  • vue中怎么使用websocket
    这篇文章主要介绍“vue中怎么使用websocket”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue中怎么使用websocket”文章能帮助大家解决问题。1. 在utils下新建websocke...
    99+
    2023-06-29
  • Vue中watch怎么使用
    这篇文章主要介绍了Vue中watch怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中watch怎么使用文章都会有所收获,下面我们一起来看看吧。一、API介绍watch(WatcherSource,...
    99+
    2023-07-04
  • Vue中的Object.defineProperty怎么用
    这篇“Vue中的Object.defineProperty怎么用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue中的Ob...
    99+
    2023-06-30
  • vue中v-for怎么用
    这篇文章将为大家详细讲解有关vue中v-for怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。用法:1、利用“v-for="(item,i) in list"”循环普通数组;2、利...
    99+
    2023-06-29
  • vue中v-if怎么用
    这篇文章给大家分享的是有关vue中v-if怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在vue中,“v-if”用于根据表达式的真假来操作DOM元素,可以切换元素的显示和隐藏;表达式的值为true时,元素存...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作