冇事来学系--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中的数据

目录
相关文章
|
8月前
|
JavaScript 前端开发 API
技术好文:vue混入(mixin)的使用
技术好文:vue混入(mixin)的使用
44 0
|
9月前
|
前端开发 JavaScript 安全
【亮剑】探讨了在React TypeScript应用中如何通过道具(props)传递CSS样式,以实现模块化、主题化和动态样式
【4月更文挑战第30天】本文探讨了在React TypeScript应用中如何通过道具(props)传递CSS样式,以实现模块化、主题化和动态样式。文章分为三部分:首先解释了样式传递的必要性,包括模块化、主题化和动态样式以及TypeScript集成。接着介绍了内联样式的基本用法和最佳实践,展示了一个使用内联样式自定义按钮颜色的例子。最后,讨论了使用CSS模块和TypeScript接口处理复杂样式的方案,强调了它们在组织和重用样式方面的优势。结合TypeScript,确保了样式的正确性和可维护性,为开发者提供了灵活的样式管理策略。
90 0
|
9月前
【Vue2.0学习】—mixin混入(五十五)
【Vue2.0学习】—mixin混入(五十五)
【Vue2.0学习】—mixin混入(五十五)
【Vue2.0学习】—计算属性(三十四)
【Vue2.0学习】—计算属性(三十四)
|
JavaScript
学习Vue3 第十四章(父子组件传参)
withDefaults是个函数也是无须引入开箱即用接受一个props函数第二个参数是一个对象设置默认值
139 0
学习Vue3 第十四章(父子组件传参)
|
缓存 JavaScript 开发者
冇事来学系--Vue2.0中动态组件和插槽slot
动态组件指的是动态切换组件的显示与隐藏。
528 0
|
JavaScript 容器
冇事来学系--Vue2.0中VueComponent(组件)
组件的本质 组件的本质就是一个 构造函数 f VueComponent (options) { this._init(options); } ,是Vue.extend( )生成的 当我们使用组件时,写了组件的标签,Vue解析时就会创建该组件的实例对象,即Vue帮我们执行了这一句代码 new VueComponent(options) (options就是我们写的data、methods、computed等数据) 每次调用Vue.extend( )时,返回的都是一个全新的VueComponent
322 0
|
存储 JavaScript 前端开发
冇事来学系--Vue2.0中vuex(上)
专门在Vue中实现集中式状态 (数据) 管理的一个Vue插件,对vue中多个组件的共享状态进行集中式的管理(读/写) ,适用于任意组件之间的通信
191 0
|
前端开发 JavaScript
好客租房67-render-props模式-3演示mouseover的组件的复用
好客租房67-render-props模式-3演示mouseover的组件的复用
113 0
好客租房67-render-props模式-3演示mouseover的组件的复用
|
JavaScript
vue混入mixin的使用,保证你看的明明白白!
vue混入mixin的使用,保证你看的明明白白!
vue混入mixin的使用,保证你看的明明白白!