vue 混入 mixin,自定义指令,过滤器
vue 混入 mixin ,分发 vue 组件中重复的功能
局部的书写格式
// mixin.js
var mymixin = { // 这是一个对象:对象里面的写法与组件里面的写法一模一样,组件该怎么写,这就怎么写
data(){
return {
a:"hello world"
}
}
}
export default mymixin // 将对象暴露出去
vue 中组件的写法
import mymixin from "./mixin.js" // 引入 mixin.js 文件
export default {
data(){
b:"hello world"
},
mixins:[mymixin], // mixins 的用法,值是一个数组,里面放着 mymixin 的对象
mounted(){
console.log(this) // 组件实例上 data 属性上便拥有了 a 属性了,而且我们在别的组件上引入 mixin.js 的话,也会拥有 a 属性
}
}
注意事项:
我们我们组件中有 data 属性,而 mixin.js 中也有 data 属性,vue 会如何处理呢?
数据对象递归合并(就是说:将 组件中的 data 属性,和 mixin.js 中的 data 属性,合并为一个 data 属性),那么还有一种情况,组件 data 中有一个 a 属性,mixin.js 的 data 中也有一个
a 属性,合并的时候,就只会合并 组件中 a 属性,mixin.js 中的 a 属性,便会被抛弃
2. 全局注入混合 mixin
上面的例子,是局部的使用 mixin ,我们每次使用都需要引入 mixin.js 的文件,那么我们所有的组件都拥有共同的内容,那么使用全局注入 mixin 再好不过了
使用方法:main.js 中
Vue.mixin({ // 全局注入混合对象
data(){
return {
a:"你好,世界"
}
}
})
这样我们的所有组件 data 中都会有 a 这个属性
当然上面的例子只是以 data 为案例,我们组件中的东西都可以写在 mixin 中,只有一个条件,那就是组件中的东西相同
自定义指令:Vue.directive(参数一,参数二) // 参数一:指令的名字 不允许带 v-,参数二:对象
案例:如 v-focus 全局注册
Vue.directive('focus',{
// 当被绑定的元素插入到 dom 中时
inserted(el){
console.log(el) // 被绑定自定义指令的 dom 元素
el.focus() // 元素的自动聚焦方法
}
})
参数二:对象上拥有的钩子函数
bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置
inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)
update:当组件的 VNode 更新时调用
钩子函数的参数:
el:指令所绑定的元素,可以用来直接操作 DOM 。
binding:是一个对象,name 指令名,value:指令值
expression:字符串形式的表达式
自定义指令的使用
<input v-focus />
过滤器 // 对数据的处理
标识符 | 俗称管道符
在 vue 组件中
局部
<h1> {{a | upper}} <h1> // 这样我们便得到的大写的 HELLO
export default {
data(){
return {
a:"hello"
}
},
filters:{
upper(value){
console.log(value) // 代表管道符前面的数据
return value.toUpperCase() // 必须 return 对前面数据的处理
}
}
}
全局处理:在 main.js 中
Vue.filter('upper', function (value) {
return value.toUpperCase() // 必须 return
})
// 这样的话所有组件都可以使用 upper 的管道符来将 字符串变大写
vue 混入 mixin,自定义指令,过滤器的更多相关文章
- vue教程2-07 自定义指令
vue教程2-07 自定义指令 自定义指令: 一.属性: Vue.directive(指令名称,function(参数){ this.el -> 原生DOM元素 }); <div v-re ...
- Vue.js 第2章 钩子函数&自定义指令&过滤器&计算属性&侦听器
目标 钩子函数 自定义指令 自定义过滤器 计算属性 监听属性 局部自定义指令 为什么需要自定义指令 为了复用,为了代码的灵活 指令的分类:全局指令,局部指令 在vm外面创建的指令 通过Vue.dire ...
- 在Vue中通过自定义指令获取元素
vue.js 是数据绑定的框架,大部分情况下我们都不需要直接操作 DOM Element,但在某些时候,我们还是有获取DOM Element的需求的: 在 vue.js 中,获取某个DOM Eleme ...
- Vue API(directives) 自定义指令
前言:除了vue的内置指令以外,我们可以定义自定义指令.内置指令表相见:https://www.cnblogs.com/ilovexiaoming/p/6840383.html 我们定义一个最简单的 ...
- vue视频: 自定义指令 && 拖拽 && 自定义键盘信息
v-textv-forv-html 指令: 扩展html语法 自定义指令:1. 自定义属性指令: Vue.directive(指令名称,function(参数){ this.el -> 原生DO ...
- Vue.js:自定义指令
ylbtech-Vue.js:自定义指令 1.返回顶部 1. Vue.js 自定义指令 除了默认设置的核心指令( v-model 和 v-show ), Vue 也允许注册自定义指令. 下面我们注册一 ...
- 在vue中创建自定义指令
原文:https://dev.to/ratracegrad/creating-custom-directives-in-vue-58hh 翻译:心上有杨 指令是带有 v- 前缀的特殊属性.指令的作用是 ...
- 浅析vue混入(mixin)
vue中的混入,可以在一定程度上提高代码的复用性.通俗来说,混入类似于“继承”,当前组件对象继承于组件对象,一般情况下遵循“就近原则”.但是与继承不同的是,继承一般都跟随着属性的重写与合并,混入在不同 ...
- Vue笔记--通过自定义指令实现按钮操作权限
经常做中后台系统,此类系统的权限是比较重要,拿自己做过的一些项目做个笔记. Vue实现的中后台管理系统.按钮操作权限的空置一般都是通过自定义指令Vue.directive. <el-button ...
随机推荐
- Python之for循环与while循环
for语句格式for x in range(起始值,结束值,步幅) 执行语句输出0,100各个数字for i in range(0,101) print(i)输出0,100的偶数for i in ra ...
- Atmel芯片使用
ATMEL系列芯片 9X35 9G35可pin-to-pin替代9G10,具体需核对.此外即使pin-to-pin替代,外部应用也不一样. A5D2处理器,可支持linux/andriod. M7(M ...
- 前端入门Js笔记
T 001 ____________--信息页面展示 需求分析: 有一个页面,在页面上有很多文字信息,且格式不一. 技术分析: html: 文字标签: 字体标签: 标题标签: 其他标签: 排版标签: ...
- 寒武纪C++日常实习生面经(其他人面试题)
1.C++继承方式? 答:public,protected,private三种继承方式和虚继承一共四种. 派生类可以继承定义在基类中的成员,但是派生类的成员函数不一定有权访问从基类继承而来的成员. 派 ...
- Alpha版本第一周小结
姓名 学号 周前计划安排 每周实际工作记录 自我打分(百分制) HTB 061126 1.博客撰写,分配任务 2.编码实现各个模块的功能 1.撰写博客 2.已初步实现各个模块的功能,对某些数据处理还存 ...
- java线程基础巩固---通过实验分析This锁和Class锁的存在
This锁: 关于什么是This锁下面用实现来说明一下它: 那下面用两个线程分别调用这两个方法,如下: 看结果: 可见两个方法是同时输出的,因为m2()方法并未上锁,所以就不存在争锁的问题,那这时给m ...
- windows通讯之evpp
- VS2008配合SQLite开发WINCE、PDA智能设备项目环境搭设。
1.安装vs2008 ---------------------------vs2008上安装TFS步骤(详细请见——http://www.cnblogs.com/mayt/archive/2013/ ...
- BZOJ 3926: [Zjoi2015]诸神眷顾的幻想乡(广义后缀自动机 多串)
因为任何一条路径都可以看做某两个叶子节点之间路径的一部分,然后分别把20个叶节点当作根,把整棵树看作trie树,那么一条路径就能看作是从根到某个点这一条路的后缀,构建SAM就能维护不同子串的个数了. ...
- CSS 定位详解
CSS 有两个最重要的基本属性,前端开发必须掌握:display 和 position position 属性的作用 position属性用来指定一个元素在网页上的位置,一共有5种定位方式,即posi ...