VUE mixin 使用示例详解
mixin 混入
<!DOCTYPE html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>hello world</title> <script src="https://unpkg.com/vue@next"></script> </head> <body> <div id="root"></div> </body> <script> const MyMixin = { data() { return { number: 2, count: 3 } } } const app = Vue.createApp({ data() { return { number: 1 } }, mixins: [MyMixin], template: ` <div>number:{ <!-- -->{number}}</div> <div>count:{ <!-- -->{count}}</div> ` }); app.mount('#root'); </script> </html>
mixin 混入可以在组件内部缺少数据时,使用mixin内的数据代替。
组件 data 优先级高于 mixin data 优先级
上述代码中,count 使用了 mixin 内的数据,由于内部 number 已经被定义,vue 优先使用内部的数据,再使用 mixin 的数据。
2 mixin 生命周期优先级
<!DOCTYPE html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>hello world</title> <script src="https://cdn.staticfile.org/vue/3.0.5/vue.global.js"></script> </head> <body> <div id="root"></div> </body> <script> const MyMixin = { created(){ console.log('mixin created') } } const app = Vue.createApp({ mixins:[MyMixin], created(){ console.log('app created') } }); app.mount('#root'); </script> </html>
mixin 中的生命周期函数和组件的生命周期函数都会执行,而且 mixin 中的优先级更高。
效果如下:
3 局部 mixin 和全局 mixin
<!DOCTYPE html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>hello world</title> <script src="https://cdn.staticfile.org/vue/3.0.5/vue.global.js"></script> </head> <body> <div id="root"></div> </body> <script> const MyMixin = { data(){ return{ number:123 } } } const app = Vue.createApp({ mixins:[MyMixin], template:`<app/>` }); app.component("app",{ template:"<div>number:{ <!-- -->{number}}</div>" }) app.mount('#root'); </script> </html>
使用 mixins:[myMixin] 是局部载入mixin的方式,子组件不能获得 mixins 的值
运行结果如下:
全局 mixin 写法:
<!DOCTYPE html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>hello world</title> <script src="https://cdn.staticfile.org/vue/3.0.5/vue.global.js"></script> </head> <body> <div id="root"></div> </body> <script> const app = Vue.createApp({ template: `<app/>` }); app.mixin({ data() { return { number: 123 } } }) app.component("app", { template: "<div>number:{ <!-- -->{number}}</div>" }) app.mount('#root'); </script> </html>
使用 app.mixin 挂载就是全局,组件可以自由使用。
效果如下:
4 自定义属性的优先级
<!DOCTYPE html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>hello world</title> <script src="https://cdn.staticfile.org/vue/3.0.5/vue.global.js"></script> </head> <body> <div id="root"></div> </body> <script> const myMixin = { value: 1 } const app = Vue.createApp({ mixins: [myMixin], value: 25, template: `<div>{ <!-- -->{this.$options.value}}</div>` }); app.mount('#root'); </script> </html>
vue 中,自定义属性就是直接写到vue下的属性,使用 this.$options.value 即可访问。
自定义属性组件的优先级比 mixin 优先级高。
结果如下:
mixin总结:
组件 data,methods优先级高于 mixin data,methods 优先级
生命周期函数,先执行 mixin 里边的,再执行组件里边的
自定义的属性,组件中的优先级高于 mixin 属性的优先级。
到此这篇关于VUE mixin 使用的文章就介绍到这了,更多相关VUE mixin 使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
在 Vue-CLI 中引入 simple-mock实现简易的 API Mock 接口数据模拟
本文以 Vue-CLI 为例介绍引入 simple-mock 实现前端开发数据模拟的步骤。感兴趣的朋友跟随小编一起看看吧2018-11-11elementUI+Springboot实现导出excel功能的全过程
这篇文章主要介绍了elementUI+Springboot实现导出excel功能,现在也对这个导出功能进行一个汇总整理写出来,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-09-09vue 跳转页面$router.resolve和$router.push案例详解
这篇文章主要介绍了vue 跳转页面$router.resolve和$router.push案例详解,这样实现了既跳转了新页面,又不会让后端检测到页面链接不安全之类的,需要的朋友可以参考下2023-10-10如何配置vue.config.js 处理static文件夹下的静态文件
这篇文章主要介绍了如何配置vue.config.js 处理static文件夹下的静态文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-06-06Vue中JSON文件神奇应用fetch、axios异步加载与模块导入全指南详细教程
在Vue中使用JSON文件有多种方式,包括使用fetch方法加载JSON文件、使用axios库加载JSON文件,以及将JSON文件导入为模块,这篇文章主要介绍了Vue中JSON文件神奇应用fetch、axios异步加载与模块导入全指南详细教程,需要的朋友可以参考下2024-01-01
最新评论