冇事来学系--Vue2.0中mixin混入(混合)和props

简介: 概念可以将各个组件中可 共有的数据和方法 抽离出来写成一个混合对象

局部混入


  • 定义混入:新建一个mixin.js文件,里面声明一个对象,保存被复用的数据和方法。并且将这个对象暴露出去
// mixin.js
const mixin = {     // 不一定命名为mixin
  // 被复用的属性和方法
}
export const hunhe = {      // 暴露的多种写法
  // 被复用的属性和方法
}
export  mixin // 这里最好使用分别暴露,别用默认暴露,因为可以声明多个混合,在组件中按需引入
  • 引入混入:根据暴露的方法,在组件中通过import引入需要用到的混入对象
  • 配置混入:在组件中配置一个mixins节点,值是一个数组,里面元素是需要使用的混入对象
import {mixin, hunhe} from '../mixin.js'
export default {
  name: 'Test',
  data(){},
  methods: {},
  mixins: [mixin,hunhe]
}
  • 若在mixin.js中写的属性和方法 与 引入它的组件中的属性和方法 产生了冲突,则以组件中的配置为准
  • 在mixin.js中写的生命周期钩子,也会在所有引入混合的组件中生效,且不会与组件本身的生命周期钩子的设置产生冲突(即两边写的都会生效)


全局混入:


全局混入需要使用Vue.mixin( )方法

  • 引入混入:在main.js中引入需要使用的混入对象
  • 配置混入:在main.js中,使用Vue.mixin( ),参数写的是需要使用的混入对象
// main.js
import Vue from 'vue'
import {mixin, hunhe} from './mixin.js'
Vue.mixin(mixin)
Vue.mixin(hunhe)

使用全局混入后,整个应用的所有组件(vc)和vm都会得到混入模块


例子:

两个组件中都要使用到一模一样的show方法,则可以将show方法抽离出来,在mixin.js中声明混入对象。在需要使用show方法的组件中进行引入和配置即可


props的功能


让组件接收外部传递的数据

  • 传递数据

在使用组件标签的时候写入,如:

  • 接收数据
  1. 简单声明接收

props: ['name', 'age', 'sex']

  1. 接收的同时对数据类型进行限制

props: {

name: String,

age: Number,

sex: String

}

  1. 更全面的设置:数据类型的限制+必要性的限制/默认值的设置

props: {

name: {

type: String,

required: true // 必传的选项

},

age: {

type: Number,

default: 18 // 非必传的选项,若没有传递此项数据,则默认值为18

},

sex: {

type: String,

required: true

}

}

注意:required和default不能一起出现

注意点

props是只读的,Vue底层会监测对props的修改。若进行修改,就会发出警告。如果业务需求确实需要修改props的数据,那么可以复制props的内容到data中,然后去修改以及渲染data中的数据

目录
相关文章
|
9月前
【Vue2.0学习】—mixin混入(五十五)
【Vue2.0学习】—mixin混入(五十五)
【Vue2.0学习】—mixin混入(五十五)
|
JavaScript
vue混入mixin的使用,保证你看的明明白白!
vue混入mixin的使用,保证你看的明明白白!
vue混入mixin的使用,保证你看的明明白白!
|
JavaScript
|
8月前
|
JavaScript 前端开发 API
技术好文:vue混入(mixin)的使用
技术好文:vue混入(mixin)的使用
46 0
|
JavaScript 开发者
冇事来学系--Vue2.0中自定义指令
什么是自定义指令 vue官方提供了v-text、v-for、v-if、v-model等指令,此外vue还允许开发者自定义指令
137 0
|
JavaScript
每日一学—vue prop属性
prop可以像调用方法那样对组件进行传参,当需要给某一个组件传递prop参数时,这个prop就成为vue组件中的data()对象的一部分,可以直接在组件作用域内使用。组件可以支持多个(n个)prop属性变量,任意类型都可以传给对应的prop。
317 0
|
开发者
冇事来学系--Vue2.0侦听器
watch侦听器允许开发者监视数据的变化,从而针对数据的变化做出特定的操作
118 0
|
缓存 JavaScript 开发者
冇事来学系--Vue2.0中动态组件和插槽slot
动态组件指的是动态切换组件的显示与隐藏。
536 0

热门文章

最新文章