Vue中在组件中单独使用this

目录

🔽 全局注册

🔽 局部注册 

🔽 组件使用总结 


🔽 全局注册

1、Vue.prototype

在多个地方都需要使用但不想污染全局作用域的情况下,这样定义,在每个 Vue 实例中都可用。
$ 表示这是一个在 Vue 所有实例中都可用的属性,常用于方法、变量

vue.prototype:实例上挂载属性/方法 

每一个vue组件都是Vue的实例,所以组件内this可以拿到Vue.prototype上添加的属性和方法。 

//main.js
import Video from 'video.js'
Vue.prototype.$video= Video//设置新的公共方法或属性为$video
// 某个页面使用注册好的组件$video
initVideo() {
  //初始化视频方法
  let myPlayer = this.$video(myVideo, {
    //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
    controls: true,
    //自动播放属性,muted:静音播放
    autoplay: "muted",
    //  autoplay: "muted",
    //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
    preload: "auto",
    //设置视频播放器的显示宽度(以像素为单位)
    width: "1300px",
    //设置视频播放器的显示高度(以像素为单位)
    height: "500px"
  });
}

prototype设置实例为什么要以$开头?

$ 是在 Vue 所有实例中都可用的 property 的一个简单约定,一种规范。这样做会避免和已被定义的数据、方法、计算属性产生冲突。 

参考:添加实例 property

2、vue.component

全局注册组件,Vue.component('组件名',对象)

第一个参数是调用组件时写的组件名

第二个参数是引入组件时写的名称

可用于注册自定义组件

import myLoading from 'base/loading'
Vue.component('my-Loading',myLoading);//初始化组件
//在其他页面使用初始化的组件
//<my-Loading><my-Loading/>

3、Vue.use

Vue.use(对象)

同样是全局注册,和component的区别是接收的参数必须有install方法

🎈 常用于注册第三方插件

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

🎈自定义插件/组件

Vue的插件是一个对象,插件对象必须有install字段。install字段是一个函数。初始化插件对象需要通过Vue.use()

使用install方法,要通过搭配全局方法 Vue.use() 使用插件(Vue.use()全局注册在main.js使用)。

//plugin.js
import moment from 'moment'
// 写插件 自定义插件/组件  并全局注册组件,但还要在main.js中全局注册一次,让其起作用
export default{
  // install  下载 必须要写  不用自己调用,vue调用     install  通过搭配全局方法 Vue.use() 使用插件(main.js使用)。
//install方法可以解决防止插件多次注册  里面的vue参数是一个对象
  install(Vue){
    console.log('@',Vue)
    Vue.prototype.$hello=function(){ console.log('hello')}
    // 时间戳
    Vue.filter('fmDate',function(value,a='YYYY'){
      return moment(value).format(a)
    })
  // 全局自定义指令
  // 自动将当前带有该指令的元素对象e,b传给回调函数的形参
  Vue.directive('small',function(e,b){
    e.innerText=b.value/10;
  });
  }
  
}//vue提供install可供我们开发新的插件及全局注册组件
//main.js
// 全局使用插件
import cj from './plugin'
Vue.use(cj)

🔽 局部注册 

局部注册实例:

components:{App,}。注意:全局注册是Vue.component()。

<template>
  <!-- 主页 用来链接路由 -->
  <div id="app">
    <!-- 3、使用组件 -->
    <Head/>  
    <router-view/>
    <Foot/>
  </div>
</template>

<script>
// 1、引入组件  公共组件
import Head from '../src/views/components/Head.vue';
import Foot from '../src/views/components/Foot.vue';
// export default默认导出
export default {
  // 2、注册组件  才能在上面用来链接路由
  components:{
    Head,
    Foot,
  },
  
}
</script>

🔽 组件使用总结 

组件的定义:实现应用中局部功能代码资源集合

非单文件组件:一个文件中包含n个组件

单文件组件:一个文件中只包含1个组件    如:一个.vue就是一个单独的组件,包含html、js、css。

步骤:

1、引入组件

2、注册组件

3、使⽤组件(编写组件标签)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

儒雅的烤地瓜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值