详解vue中v-bind:style效果的自定义指令


Posted in Javascript onJanuary 21, 2020

自定义指令

1.什么是自定义指令

以 v- 为前缀,然后加上自己定义好的名字组成的一个指令就是自定义指令。为什么要有自定义指令呢?在有些时候,你仍然需要对普通的DOM元素进行底层的操作,这个时候就可以用到自定义指令。

2.自定义指令的语法

全局自定义指令

// 注册一个全局自定义指令 `v-focus`
Vue.directive('focus', {
 // 当被绑定的元素插入到 DOM 中时……
 inserted: function (el) {
  // 聚焦元素
  el.focus()
 }
})

局部自定义指令

directives: {
 focus: {
  // 指令的定义
  inserted: function (el) {
   el.focus()
  }
 }
}

3.钩子函数

看了上述的代码,如果你从来没接触过这类内容,你可能会很生疏,下面我给大家讲讲其每一步所需要掌握的东西

首先是钩子函数:

bind :只会调用一次的函数,表示指令第一次绑定元素时调用

inserted :被绑定元素插入到父节点时调用(仅保证父节点存在,但不一定已被插入文档中)。

update :所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。

componentUpdated :指令所在组件的 VNode 及其子 VNode 全部更新后调用。

unbind :只调用一次,指令与元素解绑时调用。

然后我们看看钩子函数中的参数列表:

el:指令所绑定的元素,可以用来直接操作 DOM 。

binding:一个对象,包含以下属性:

name:指令名,不包括 v- 前缀。

value:指令的绑定值,例如:

v-my-directive="1 + 1" 中,绑定值为 2

oldValue:指令绑定的前一个值,仅在 updatecomponentUpdated 钩子中可用。无论值是否改变都可用。expression:字符串形式的指令表达式。例

v-my-directive="1 + 1" 中,表达式为 "1 + 1"arg:传给指令的参数,可选。

例如 v-my-directive:foo 中,参数为 "foo"

modifiers:一个包含修饰符的对象。例如:v-my-directive.foo.bar 中,修饰符对象为 { foo: true, bar: true }vnode:Vue 编译生成的虚拟节点。

oldVnode:上一个虚拟节点,仅在 updatecomponentUpdated 钩子中可用。

除了 el 之外,其它参数都应该是只读的,切勿进行修改。如果需要在钩子之间共享数据,建议通过元素的 dataset 来进行。

下面我们来分析几个简单的钩子函数,及其参数

代码如下:(看完代码我再将其)

<div id="app">
 <span v-mmm='{color:color, fontSize:"20px"}'>bind的对象形式</span>
 <br>
 <button @click='changeStyle'>改变颜色</button>
</div>

<script>
 const vm = new Vue({
  el: '#app',
  data: {
   color: 'cyan',
   style1: {color: 'lightblue'},
   style2: {fontSize:"20px"}
  },
  directives: {
   mmm: {
    bind(el,binding) {
     // binding.value = {color:color, fontSize:"20px"}
     if(binding.value.constructor === Object) {
      Object.keys(binding.value).forEach(key => {
       el.style[key] = binding.value[key];
      })
     }
    }
   }
  },
  methods: {
   changeStyle() {
    this.color = 'lightpink'
   }
  },
 })
</script>

效果图:

详解vue中v-bind:style效果的自定义指令

下面我们换成 update 钩子函数:

update(el,binding) {
 // binding.value = {color:color, fontSize:"20px"}
 if(binding.value.constructor === Object) {
  Object.keys(binding.value).forEach(key => {
   el.style[key] = binding.value[key];
  })
 }
}

效果图:

详解vue中v-bind:style效果的自定义指令

当我们点击按钮后:

详解vue中v-bind:style效果的自定义指令

我们发现他会随着数据改变而更新,但是他刚开始不会调用它,只有当数据发生改变之后才会调用该钩子函数

如果我们想要要刚开始就调用,并且会跟随数据改变而改变,那么我们就要同时调用 bindupdate 这两个钩子函数,但是两个钩子函数中的内容又是一样的,那么书写起来就很麻烦。那么我们可以这样写:

mmm: function(el , binding) {
 if(binding.value.constructor === Object) {
  Object.keys(binding.value).forEach(key => {
   el.style[key] = binding.value[key];
  })
 }
},

这样之后我们就可以达到那样的效果了。

书写一个类似于 v-bind:style 的效果的自定义指令

<div id="app">
 <span v-mystyle='{color:color, fontSize:"20px"}'>v-mystyle的对象形式</span>

 <p v-mystyle='[style1 , style2]'>我使用的是v-mystyle的数组形式</p>

 <button @click='changeStyle'>改变颜色</button>
</div>

<script>
 const vm = new Vue({
  el: '#app',
  data: {
   color: 'cyan',
   style1: {color: 'lightblue'},
   style2: {fontSize:"20px"}
  },
  directives: {
   mystyle: function(el , binding) {
    if(binding.value.constructor === Object) {
     Object.keys(binding.value).forEach(key => {
      el.style[key] = binding.value[key];
     })
    } else if(binding.value.constructor === Array) {
     for(item of binding.value) {
      for(key in item) {
       el.style[key] = item[key];
      }
     }
    }
   },
  },
  methods: {
   changeStyle() {
    this.color = 'lightpink'
   }
  },
 })
</script>

效果图:

详解vue中v-bind:style效果的自定义指令

详解vue中v-bind:style效果的自定义指令

补充:下面看下v-bind绑定style的几种方式

<!DOCTYPE html>
<HTML>
<HEAD>
  <TITLE>VUE --- V-BIND绑定STYLE的几种方式</TITLE>
</HEAD>
<BODY>
  <DIV ID="APP1">
    <DIV :STYLE="{'COLOR':COLOR,'FONTSIZE':SIZE+'PX'}">第一个示例</DIV>
  </DIV>

  <DIV ID="APP2">
    <DIV :STYLE="STYLES">第二种方式</DIV>
  </DIV>
  <SCRIPT TYPE="TEXT/JAVASCRIPT" SRC="HTTPS://UNPKG.COM/VUE/DIST/VUE.MIN.JS"></SCRIPT>
  <SCRIPT TYPE="TEXT/JAVASCRIPT">
    VAR APP1 = NEW VUE({
      EL:'#APP1',
      DATA:{
        COLOR:'RED',
        SIZE:15
      }
    })

    VAR APP2 = NEW VUE({
      EL:'#APP2',
      DATA:{
        STYLES:{
          COLOR:'RED',
          FONTSIZE:15+'PX'
        }
      }
    })
  </SCRIPT>
</BODY>
</HTML>

总结

以上所述是小编给大家介绍的vue中v-bind:style效果的自定义指令,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
30个精美的jQuery幻灯片效果插件和教程
Aug 23 Javascript
js移除事件 js绑定事件实例应用
Nov 28 Javascript
JQueryEasyUI datagrid框架的基本使用
Apr 08 Javascript
JS实现仿FLASH效果的竖排导航代码
Sep 15 Javascript
Javascript在IE和Firefox浏览器常见兼容性问题总结
Aug 03 Javascript
Angular Module声明和获取重载实例代码
Sep 14 Javascript
详解AngularJS验证、过滤器、指令
Jan 04 Javascript
清空元素html(&quot;&quot;) innerHTML=&quot;&quot; 与 empty()的区别和应用(推荐)
Aug 14 Javascript
react-native动态切换tab组件的方法
Jul 07 Javascript
默认浏览器设置及vue自动打开页面的方法
Sep 21 Javascript
Vue 子组件与数据传递问题及注意事项
Jul 11 Javascript
JavaScript实现单点登录的示例
Sep 23 Javascript
vue.js iview打包上线后字体图标不显示解决办法
Jan 20 #Javascript
Angular单元测试之事件触发的实现
Jan 20 #Javascript
vue elementui 实现搜索栏公共组件封装的实例代码
Jan 20 #Javascript
D3.js 实现带伸缩时间轴拓扑图的示例代码
Jan 20 #Javascript
阿望教你用vue写扫雷小游戏
Jan 20 #Javascript
JavaScript Window窗口对象属性和使用方法
Jan 19 #Javascript
浅谈webpack和webpack-cli模块源码分析
Jan 19 #Javascript
You might like
PHPExcel读取Excel文件的实现代码
2011/12/06 PHP
php安全开发 添加随机字符串验证,防止伪造跨站请求
2013/02/14 PHP
php正则替换处理HTML页面的方法
2015/06/17 PHP
smarty的section嵌套循环用法示例
2016/05/28 PHP
php 调用百度sms来发送短信的实现示例
2018/11/02 PHP
PHP实现的权重算法示例【可用于游戏根据权限来随机物品】
2019/02/15 PHP
wordpress之js库集合研究介绍
2007/08/17 Javascript
070823更新的一个[消息提示框]组件 兼容ie7
2007/08/29 Javascript
javascript学习笔记(十) js对象 继承
2012/06/19 Javascript
网页中可关闭的漂浮窗口实现可自行调节
2013/08/20 Javascript
jquery.ui.draggable中文文档(原文翻译)
2013/11/15 Javascript
JS事件在IE与FF中的区别详细解析
2013/11/20 Javascript
javacript获取当前屏幕大小
2016/06/04 Javascript
three.js绘制地球、飞机与轨迹的效果示例
2017/02/28 Javascript
JS实现AES加密并与PHP互通的方法分析
2017/04/19 Javascript
详解ElementUI之表单验证、数据绑定、路由跳转
2017/06/21 Javascript
EasyUI的TreeGrid的过滤功能的解决思路
2017/08/08 Javascript
vue实现抖音时间转盘
2019/09/08 Javascript
Vuex的各个模块封装的实现
2020/06/05 Javascript
jquery插件实现轮播图效果
2020/10/19 jQuery
利用PHP实现递归删除链表元素的方法示例
2020/10/23 Javascript
jQuery实现鼠标拖动图片功能
2021/03/04 jQuery
Python中的True,False条件判断实例分析
2015/01/12 Python
Python抓取手机号归属地信息示例代码
2016/11/28 Python
pycharm下查看python的变量类型和变量内容的方法
2018/06/26 Python
[原创]Python入门教程1. 基本运算【四则运算、变量、math模块等】
2018/10/28 Python
Python配置虚拟环境图文步骤
2019/05/20 Python
python轮询机制控制led实例
2020/05/03 Python
django在开发中取消外键约束的实现
2020/05/20 Python
django rest framework 过滤时间操作
2020/07/12 Python
使用placeholder属性设置input文本框的提示信息
2020/02/19 HTML / CSS
美国美妆网站:B-Glowing
2016/10/12 全球购物
波兰在线杂货店:Polski Koszyk
2019/11/02 全球购物
客房领班岗位职责
2015/02/11 职场文书
开业典礼致辞
2015/07/29 职场文书
oracle重置序列从0开始递增1
2022/02/28 Oracle