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

目录
相关文章
|
6月前
|
JavaScript 前端开发 API
技术好文:vue混入(mixin)的使用
技术好文:vue混入(mixin)的使用
39 0
|
7月前
|
前端开发 JavaScript 安全
【亮剑】探讨了在React TypeScript应用中如何通过道具(props)传递CSS样式,以实现模块化、主题化和动态样式
【4月更文挑战第30天】本文探讨了在React TypeScript应用中如何通过道具(props)传递CSS样式,以实现模块化、主题化和动态样式。文章分为三部分:首先解释了样式传递的必要性,包括模块化、主题化和动态样式以及TypeScript集成。接着介绍了内联样式的基本用法和最佳实践,展示了一个使用内联样式自定义按钮颜色的例子。最后,讨论了使用CSS模块和TypeScript接口处理复杂样式的方案,强调了它们在组织和重用样式方面的优势。结合TypeScript,确保了样式的正确性和可维护性,为开发者提供了灵活的样式管理策略。
80 0
|
7月前
【Vue2.0学习】—mixin混入(五十五)
【Vue2.0学习】—mixin混入(五十五)
【Vue2.0学习】—mixin混入(五十五)
|
7月前
【Vue2.0学习】—Todolist案例自定义事件(六十)
【Vue2.0学习】—Todolist案例自定义事件(六十)
|
缓存 JavaScript C++
Vue2向Vue3过度核心技术computed计算属性
Vue2向Vue3过度核心技术computed计算属性
114 0
|
网络架构 C++
Vue2向Vue3过度核心技术声明式导航
Vue2向Vue3过度核心技术声明式导航
66 0
【Vue3 第十五章】组件中的双向绑定
【Vue3 第十五章】组件中的双向绑定
117 0
|
缓存 JavaScript C++
【Vue3 第七章】computed 计算属性
【Vue3 第七章】computed 计算属性
227 0
|
JavaScript
学习Vue3 第十四章(父子组件传参)
withDefaults是个函数也是无须引入开箱即用接受一个props函数第二个参数是一个对象设置默认值
129 0
学习Vue3 第十四章(父子组件传参)