},
unbind(el) {
document.removeEventListener(‘click’, el.vueMenuHandler)
delete el.vueMenuHandler
}
})
new Vue({
el: ‘#app’,
data: {
show: false
},
methods: {
handleHide() {
this.show = false
}
}
})
<button @click=“show = !show”>点击显示下拉菜单
3. 相对时间转换
类似微博、朋友圈发布动态后的相对时间,比如刚刚、两分钟前等等
new Vue({
el: ‘#app’,
data: {
time: 1565753400000
}
})
Vue.directive(‘relativeTime’, {
bind(el, binding) {
// Time.getFormatTime() 方法,自行补充
el.innerHTML = Time.getFormatTime(binding.value)
el.timeout = setInterval(() => {
el.innerHTML = Time.getFormatTime(binding.value)
}, 6000)
},
unbind(el) {
clearInterval(el.innerHTML)
delete el.timeout
}
})
[
新人创作打卡挑战赛
发博客就能抽奖!定制产品红包拿不停!
](https://blogdev.blog.csdn.net/article/details/124124117?utm_campaign=marketingcard&utm_source=weixin_43638968&utm_content=103611397)
最后
全网独播-价值千万金融项目前端架构实战
从两道网易面试题-分析JavaScript底层机制
RESTful架构在Nodejs下的最佳实践
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
一线互联网企业如何初始化项目-做一个自己的vue-cli
思维无价,看我用Nodejs实现MVC
代码优雅的秘诀-用观察者模式深度解耦模块
前端高级实战,如何封装属于自己的JS库
VUE组件库级组件封装-高复用弹窗组件
件库级组件封装-高复用弹窗组件