iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >vue中有哪些自定义指令
  • 858
分享到

vue中有哪些自定义指令

2023-06-22 02:06:22 858人浏览 八月长安
摘要

这篇文章主要介绍“Vue中有哪些自定义指令”,在日常操作中,相信很多人在vue中有哪些自定义指令问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中有哪些自定义指令”的疑惑有所帮助!接下来,请跟着小编一起来

这篇文章主要介绍“Vue中有哪些自定义指令”,在日常操作中,相信很多人在vue中有哪些自定义指令问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中有哪些自定义指令”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

vue中有哪些自定义指令

四个实用的vue自定义指令

1、v-drag

需求:鼠标拖动元素

思路:

  • 元素偏移量 = 鼠标滑动后的坐标 - 鼠标初始点击元素时的坐标 + 初始点击时元素距离可视区域的top、left。

  • 将可视区域作为边界,限制在可视区域里面拖拽。

    代码:

    Vue.directive('drag', {  inserted(el) {    let header = el.querySelector('.dialog_header')    header.style.CSSText += ';cursor:move;'    header.onmousedown = function (e) {      //获取当前可视区域宽、高      let clientWidth = document.documentElement.clientWidth      let clientHeight = document.documentElement.clientHeight      //获取自身宽高      let elWidth = el.getBoundinGClientRect().width      let elHeight = el.getBoundingClientRect().height      //获取当前距离可视区域的top、left      let elTop = el.getBoundingClientRect().top      let elLeft = el.getBoundingClientRect().left      //获取点击时候的坐标      let startX = e.pageX      let startY = e.pageY      document.onmousemove = function (e) {        //元素偏移量 = 鼠标滑动后的坐标 - 鼠标初始点击元素时的坐标 + 初始点击时元素距离可视区域的top、left        let moveX = e.pageX - startX + elLeft        let moveY = e.pageY - startY + elTop        //将可视区域作为边界,限制在可视区域里面拖拽        if ((moveX + elWidth) > clientWidth || moveX < 0 || (moveY + elHeight) > clientHeight || moveY < 0) {          return        }        el.style.cssText += 'top:' + moveY + 'px;left:' + moveX + 'px;'      }      document.onmouseup = function () {        document.onmousemove = null        document.onmouseup = null      }    }  }})

    2、v-Wordlimit

    需求:后台字段限制了长度,并且区分中英文,中文两个字节,英文一个字节;所以输入框需要限制输入的字数并且区分字节数,且需回显已输入的字数。

    思路:

    • 一个字节的正则/[\x00-\xff]/g

    • 创建包裹字数限制的元素,并定位布局在textarea和input框上

    • 分别计算输入的字符一个字节的有enLen个,两个字节的有cnLen个;用来后面字符串截断处理

    • 当输入的字数超过限定的字数,截断处理;substr(0,enLen+cnLen)

    • 接口更新了输入框的值,或者初始化输入框的值,需要回显正确的字节数

    代码:

    Vue.directive('wordlimit',{  bind(el,binding){    console.log('bind');    let { value } = binding    Vue.nextTick(() =>{      //找到输入框是textarea框还是input框      let current = 0      let arr = Array.prototype.slice.call(el.children)      for (let i = 0; i < arr.length; i++) {        if(arr[i].tagName=='TEXTAREA' || arr[i].tagName=='INPUT'){          current = i        }      }        //更新当前输入框的字节数      el.children[el.children.length-1].innerhtml = el.children[current].value.replace(/[^\x00-\xff]/g,'**').length +'/'+value//eslint-disable-line    })  },  update(el,binding){    console.log('update');    let { value } = binding    Vue.nextTick(() =>{      //找到输入框是textarea框还是input框      let current = 0      let arr = Array.prototype.slice.call(el.children)      for (let i = 0; i < arr.length; i++) {        if(arr[i].tagName=='TEXTAREA' || arr[i].tagName=='INPUT'){          current = i        }      }        //更新当前输入框的字节数      el.children[el.children.length-1].innerHTML = el.children[current].value.replace(/[^\x00-\xff]/g,'**').length +'/'+value//eslint-disable-line    })  },  inserted(el,binding){    console.log('inserted');    let { value } = binding    //找到输入框是textarea框还是input框    let current = 0    let arr = Array.prototype.slice.call(el.children)    for (let i = 0; i < arr.length; i++) {      if(arr[i].tagName=='TEXTAREA' || arr[i].tagName=='INPUT'){        current = i      }    }    //创建包裹字数限制的元素,并定位布局在textarea和input框上    let div = document.createElement('div')    if(el.children[current].tagName=='TEXTAREA'){//是textarea,定位在右下角      div.style = 'color:#909399;position:absolute;font-size:12px;bottom:5px;right:10px;'    }else{      let styStr = ''      if(!el.classList.contains('is-disabled')){//input框不是置灰的状态则添加背景颜色        styStr = 'background:#fff;'      }      div.style = 'color:#909399;position:absolute;font-size:12px;bottom:2px;right:10px;line-height:28px;height:28px;'+styStr    }    div.innerHTML = '0/'+ value    el.appendChild(div)    el.children[current].style.paddingRight = '60px'    el.oninput = () =>{      let val = el.children[current].value      val = val.replace(/[^\x00-\xff]/g,'**') //eslint-disable-line      // 字数限制的盒子插入到el后是最后一个元素      el.children[el.children.length-1].innerHTML = val.length + '/' + value      if(val.length>value){        let cnLen = 0 //一个字节的字数        let enLen = 0 //两个字节的字数        if(val.match(/[^**]/g) && val.match(/[^**]/g).length){          enLen = val.match(/[^**]/g).length // 计算一个字节的字数          //一个字节两个字节都有的情况          if((value - val.match(/[^**]/g).length)>0){            cnLen = Math.floor((value - val.match(/[^**]/g).length)/2)          }else{            cnLen = 0          }        }else{ //全部两个字节的情况          enLen = 0          cnLen = Math.floor(value/2)        }        if(enLen>value){          enLen = value        }        //超过限定字节数则截取        el.children[current].value = el.children[current].value.substr(0,enLen+cnLen)        //更新当前输入框的字节数        el.children[el.children.length-1].innerHTML = el.children[current].value.replace(/[^\x00-\xff]/g,'**').length +'/'+value//eslint-disable-line      }    }  },})

    使用:

    <el-input type="textarea" rows="3" v-wordlimit="20" v-model="value"></el-input>

    3、v-anthor

    需求:点击某个元素(通常是标题、副标题之类的),动画滚动到对应的内容块

    思路:

    • 定时器使用window.scrollBy

    • 不考虑ie的话,可直接使用  window.scrollBy({ top: ,left:0,behavior:'smooth' })

    代码:

    Vue.directive('anchor',{  inserted(el,binding){    let { value } = binding    let timer = null    el.addEventListener('click',function(){      // 当前元素距离可视区域顶部的距离      let currentTop = el.getBoundingClientRect().top      animateScroll(currentTop)    },false)        function animateScroll(currentTop){      if(timer){        clearInterval(timer)      }      let c = 9      timer = setInterval(() =>{        if(c==0){          clearInterval(timer)        }        c--        window.scrollBy(0,(currentTop-value)/10)      },16.7)    }  }})

    使用:

    <div class="box" v-anchor="20" style="color:red;">是的</div>

    4、v-hasRole

    需求:根据系统角色添加或删除相应元素

    代码:

    Vue.directive('hasRole',{  inserted(el,binding){    let { value } = binding    let roles = JSON.parse(sessionStorage.getItem('userInfo')).roleIds    if(value && value instanceof Array && value.length>0){      let hasPermission = value.includes(roles)      if(!hasPermission){        el.parentnode && el.parentNode.removeChild(el)      }    }else{      throw new Error(`请检查指令绑定的表达式,正确格式例如 v-hasRole="['admin','reviewer']"`)    }  }})

    到此,关于“vue中有哪些自定义指令”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

    --结束END--

    本文标题: vue中有哪些自定义指令

    本文链接: https://www.lsjlt.com/news/301993.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • vue中有哪些自定义指令
      这篇文章主要介绍“vue中有哪些自定义指令”,在日常操作中,相信很多人在vue中有哪些自定义指令问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中有哪些自定义指令”的疑惑有所帮助!接下来,请跟着小编一起来...
      99+
      2023-06-22
    • Vue中有哪些常用的自定义指令
      Vue中有哪些常用的自定义指令,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在 Vue,除了核心功能默认内置的指令 ( v-model 和...
      99+
      2022-10-19
    • vue自定义指令的方法有哪些
      在vue中自定义指令的方法有:语法:Vue.directive(id, definition);1.自定义全局指令;2.自定义私有指令;在vue中自定义指令的方法有以下两种vue自定义指令语法:Vue.directive(id, ...
      99+
      2022-10-22
    • Vue实用的自定义指令有哪些
      这篇文章主要讲解了“Vue实用的自定义指令有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue实用的自定义指令有哪些”吧!前言:Vue自定义指令有全局注册和局部注册两种方式。先来看看注...
      99+
      2023-06-29
    • Vue中的自定义指令有哪些及怎么使用
      本篇内容主要讲解“Vue中的自定义指令有哪些及怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue中的自定义指令有哪些及怎么使用”吧!1、什么是自定义指令vue 官方提供了 v-text...
      99+
      2023-06-30
    • Vuejs中常用的自定义指令有哪些
      这篇文章主要为大家展示了“Vuejs中常用的自定义指令有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vuejs中常用的自定义指令有哪些”这篇文章吧。在Vuejs中,自定义一些指令对底层DO...
      99+
      2023-06-20
    • vue中的自定义指令clickOutside
      目录自定义指令clickOutside首先我们先看看vue官方的文档clickoutside 这个指令用在哪里呢?写法自定义指令clickoutside使用及扩展用法自定义指令cli...
      99+
      2022-11-13
    • Vue中如何自定义指令
      这篇文章主要介绍Vue中如何自定义指令,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Vue中除了内置指令,也允许注册自定义的指令。自定义指令提供一种将数据的变化映射为DOM的行为例如:当我们想用一个函数表示焦点Vue...
      99+
      2023-06-04
    • Vue自定义指令详解
      目录Vue自定义指令自定义指令钩子函数输出相关属性运用例子总结Vue自定义指令 自定义指令 注册一个全局指令v-focus,该指令的功能是在页面加载时元素获得焦点 <!DO...
      99+
      2022-11-12
    • Vue自定义指令详细
      目录1、背景2、局部自定义指令3、全局自定义指令4.1 自定义指令钩子函数4.2 钩子函数参数4.3 动态指令传参 5、拓展1、背景 最近在面试找工作,然后面试官就问了有关自定义指令...
      99+
      2022-11-12
    • vue自定义指令directive有什么用
      这篇文章主要介绍了vue自定义指令directive有什么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体内容如下所示: 官网...
      99+
      2022-10-19
    • vue中自定义指令怎么用
      小编给大家分享一下vue中自定义指令怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、v-drag需求:鼠标拖动元素思路:元素偏移量 = 鼠标滑动后的坐标 - 鼠标初始点击元素时的坐标 + 初始点击时元素距离可视区域...
      99+
      2023-06-22
    • vue全局自定义指令和局部自定义指令的使用
      目录局部自定义指令(只针对组件内的元素)定义全局自定义指令自定义指令的钩子函数自定义指令钩子函数的参数例子除了默认设置的核心指令 (v-model 和 v-show),Vue 也允许...
      99+
      2022-11-13
    • Vue自定义指令怎么写
      小编给大家分享一下Vue自定义指令怎么写,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是Vue指令指令是一种可以附加到DOM...
      99+
      2022-10-19
    • vue中自定义指令directive的详细指南
      目录一、 什么是自定义指令二、 如何自定义指令钩子函数三、应用场景输入框防抖图片懒加载一键 Copy的功能拖拽总结一、 什么是自定义指令 我们看到的v-开头的行内属性,都是指令,不...
      99+
      2022-11-12
    • Vue中如何使用自定义指令
      今天就跟大家聊聊有关Vue中如何使用自定义指令,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.自定义指令的语法Vue自定义指令语法如下:Vue.d...
      99+
      2022-10-19
    • vue如何自定义加载指令
      本文小编为大家详细介绍“vue如何自定义加载指令”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue如何自定义加载指令”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言用过element-ui的都应该知道,里面...
      99+
      2023-07-02
    • vue如何使用自定义指令
      这篇文章将为大家详细讲解有关vue如何使用自定义指令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 使用自定义指令的逻辑与使用事件修饰符的逻辑...
      99+
      2022-10-19
    • vue中的自定义指令如何使用
      这篇文章主要介绍“vue中的自定义指令如何使用”,在日常操作中,相信很多人在vue中的自定义指令如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中的自定义指令如何使用”的疑惑有所帮助!接下来,请跟...
      99+
      2023-06-29
    • Vue中自定义图片懒加载指令
      本篇文章为大家展示了Vue中自定义图片懒加载指令,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。先看如何使用这个指令:  <img v-lazyloa...
      99+
      2022-10-19
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作