技术点
- 钩子函数
- 自定义指令
- 自定义过滤器
- 计算属性
- 监听属性
自定义指令
为什么需要自定义指令?
- 为了代码复用和灵活。
指令的分类:
全局指令:
- 在vm实例外面创建的指令;
- 通过Vue.directive来创建;
局部指令:以后补充
如何定义自定义指令?(不用赋值)
- Vue.directive(指令名称, {inserted(el,binding){}})
如何使用自定义指令?(不用赋值)
- v-指令名称
如何定义带值的指令?
- Vue.directive(名称, {inserted(el,binding){binding.value}})
如何使用需要赋值的指令?
- v-指令名称='值'
-
mounted钩子函数,它是一个独立的结构,不要写在methods属性中
-
钩子函数:在某个场景会自动触发的函数
不建议使用原生dom的方式去获取元素,因为vue就是希望能够将我们从繁琐的dom操作中解脱
-
ref='标记值'
-
功能类似于之前的id设置
-
获取值通过this.$refs
上面的实现方式虽然可以,但是有一个重大 的缺点:如果需要获取焦点的元素发生变化,那和以意味着模板代码和mounted钩子函数中的代码也需要进行修改--不方便也不合理。我希望达到这样的效果:我做出一个能够让元素获取焦点的功能(函数),如果元素需要获取焦点就进行调用,否则就当它不存在--这个玩意就是指令;
指令:可以实现某种功能,用户可以选择使用
什么是全局自定义指令 :在vue实例外创建的指令
如何创建全局自定义指令
Vue.directive(名称,{inserted钩子函数})
inserted钩子函数:在添加指令的元素插入到父节点时触发--说白了就是生成dom树
Vue.directive('focus',{ //el:就是当前添加了这个指令的元素,el可以用于直接操作dom inserted(el,binding,vNode){ // 我们需要获取元素并设置聚焦 console.log(el) el.focus() } })
新的需求:我们需要根据用户的喜好来修改文本颜色
通过指令来实现
通过Vue.directive(名称,{inserted(el,binding){}})
使用指令的时候:v-名称='值'
// 设置颜色的自定义指令 Vue.directive('setcolor',{ // el:当前使用这个指令的元素 // binding:它是一个对象,里面有一个属性value,就是当前指令所绑定的值 inserted(el,binding){ console.log(binding) el.style.color = binding.value } })
细节:
命名细节:建议定义指令的时候命名都是小写
update钩子函数可处理当数据或者模板内容发生变化的时候就自动的触发
// 添加update,监听指令的值的变化,以便页面进行刷新 update(el,binding){ console.log(el) console.log(binding) el.style.color = binding.value }
过滤器
作用:对传入的数据进行处理,返回合理的结果
-
全局过滤器:在vm实例之前(外面)创建的过滤器
-
局部过滤器:在组件内部创建的过滤器
- Vue.filter(名称,函数)
细节
-
-
如果你手动传递了参数,也不会影响默认参数的传递,意味着过滤器中直接在默认参数后添加新的接收形参就可以了
-
过滤器的函数“一定”要写return,因为过滤器一定要返回结果
如何调用?
-
-
格式:需要调用过滤器的数据 | 过滤器名称
// 添加全局的自定义过滤器 Vue.filter('timeForamt', (date,seperator1) => { // var date = new Date(); // var seperator1 = "/"; var year = date.getFullYear(); var month = date.getMonth() + 1; var strDate = date.getDate(); if (month >= 1 && month <= 9) { month = "0" + month; } if (strDate >= 0 && strDate <= 9) { strDate = "0" + strDate; } var currentdate = year + seperator1 + month + seperator1 + strDate; return currentdate; })
计算属性
-
你在计算属性中定义是的函数,但是可以像使用普通属性一样来使用计算属性
-
里面的函数是一个属性,所以不能以函数的方式进行调用,否则报错
-
当计算属性中依赖的数据发生变化的时候,这个计算属性就会被触发
-
所谓依赖的数据就是指里面所依赖的this的成员
-
普通方法没有缓存机制,只要你使用到了方法,就必须进行方法的调用执行
-
而计算属性是基本依赖进行缓存的,意味着只要依赖项的值没有变化,那么计算属性不会再重新的调用,而是使用上一次的计算结果--提高效率
使用计算属性实现搜索功能
computed: { search(){ // 监听用户关键字的变化,只是用户输入有变化,就需要重新进行搜索 // 计算属性中的函数一般都会返回一个计算结果 // var result = [] // for(var i=0;i// // 说明这个对象的name值中包含关键字,这就是我要找的记录之一 // // 如果没有输入任何的关键字,那么this.userKey默认就是"" // if(this.brandList[i].name.indexOf(this.userKey) != -1){ // result.push(this.brandList[i]) // } // } // return result // 每次都会从数组中取出一个值,传递给回调函数中的参数value // 在回调函数中对Value进行检测判断如果满足条件,那么就会将value值存储到filter方法内部创建的临时数组arr中,最终将这个数组arr返回 // forEach map filter return this.brandList.filter((value) => { return value.name.indexOf(this.userKey) != -1 }) } }
计算属性有一个不足:不能响应异步操作的结果。如果需要监听异步操作时数据的变化,就需要使用到watch
-
侦听器是一个属性
-
里面的方法名称不能随意,必须和你需要侦听的属性名称完全一致
watch:{ // 方法的名称必须和你想要侦听的data中的成员名称一致 first(newvalue,oldvalue){ setTimeout(() => { console.log(newvalue,oldvalue) this.fullname = newvalue.trim().toUpperCase() +":"+this.second }, 100); }, second(newvalue,oldvalue){ console.log(newvalue,oldvalue) } }
-
什么是深度监听:不再是this的直接成员,面是this的成员的成员
两种实现方式
-
-
'对象.属性'(){}
obj:{ // 通过handler函数进行侦听 handler(nv,ov){ console.log(nv.name,nv.age) }, // 设置为深度侦听 deep:true } // 侦听指定的成员值的变化 'obj.name' (nv){ console.log(nv) }
什么时候使用侦听器?
- 当数据操作涉及到异步方式的时候,就需要使用侦听器
品牌管理系统效果
代码地址:https://github.com/C4az6/Vue_study