详解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 相关文章推荐
js文字滚动停顿效果代码
Jun 28 Javascript
最好用的省市二级联动 原生js实现你值得拥有
Sep 22 Javascript
javascript中返回顶部按钮的实现
May 05 Javascript
AngularJS基础 ng-focus 指令简单示例
Aug 01 Javascript
如何理解Vue的作用域插槽的实现原理
Aug 19 Javascript
微信小程序模板和模块化用法实例分析
Nov 28 Javascript
vue-quill-editor+plupload富文本编辑器实例详解
Oct 19 Javascript
微信小程序登录session的使用
Mar 17 Javascript
vue移动端城市三级联动组件使用详解
Jul 26 Javascript
原生JS实现顶部导航栏显示按钮+搜索框功能
Dec 25 Javascript
vue中实现点击变成全屏的多种方法
Sep 27 Javascript
Vue——前端生成二维码的示例
Dec 19 Vue.js
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
phpmyadmin操作流程
2006/10/09 PHP
深入PHP中的HashTable结构详解
2013/06/13 PHP
php中读写文件与读写数据库的效率比较分享
2013/10/19 PHP
迅速确定php多维数组的深度的方法
2014/01/07 PHP
PHP结合jquery ajax实现上传多张图片,并限制图片大小操作示例
2019/03/01 PHP
Thinkphp5.0 框架Model模型简单用法分析
2019/10/11 PHP
比较详细的关于javascript中void(0)的具体含义解释
2007/08/02 Javascript
jquery的ajax请求全面了解
2013/03/20 Javascript
jquery用get实现ajax在ie里面刷新不进入后台解决方法
2013/08/12 Javascript
用JavaScript实现用一个DIV来包装文本元素节点
2014/09/09 Javascript
jQuery检测某个元素是否存在代码分享
2015/07/09 Javascript
angularjs实现分页和搜索功能
2018/01/03 Javascript
angularjs $http调用接口的方式详解
2018/08/13 Javascript
微信小程序 swiper 组件遇到的问题及解决方法
2019/05/26 Javascript
JS Html转义和反转义(html编码和解码)的实现与使用方法总结
2020/03/10 Javascript
vue.js中使用微信扫一扫解决invalid signature问题(完美解决)
2020/04/11 Javascript
微信小程序实现点击生成随机验证码
2020/09/09 Javascript
小程序实现录音功能
2020/09/22 Javascript
Python 初始化多维数组代码
2008/09/06 Python
Python操作sqlite3快速、安全插入数据(防注入)的实例
2014/04/26 Python
1分钟快速生成用于网页内容提取的xslt
2018/02/23 Python
解决PyCharm import torch包失败的问题
2018/10/13 Python
Python实现对特定列表进行从小到大排序操作示例
2019/02/11 Python
2021年的Python 时间轴和即将推出的功能详解
2020/07/27 Python
python批量生成身份证号到Excel的两种方法实例
2021/01/14 Python
微软香港官网及网上商店:Microsoft HK
2016/09/01 全球购物
玩具反斗城西班牙网上商城:ToysRUs西班牙
2017/01/19 全球购物
英国乐购杂货:Tesco Groceries
2018/11/29 全球购物
微型企业创业投资计划书
2014/01/10 职场文书
《兰亭集序》教学反思
2014/02/11 职场文书
四风对照检查材料范文
2014/09/27 职场文书
学生穿着不得体检讨书
2014/10/12 职场文书
党员作风建设自查报告
2014/10/23 职场文书
学习商务礼仪心得体会
2016/01/22 职场文书
阿里云服务器搭建Php+Apache运行环境的详细过程
2021/05/15 PHP
SpringCloud中分析讲解Feign组件添加请求头有哪些坑梳理
2022/06/21 Java/Android