亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue中4個(gè)自定義指令講解及實(shí)例用法

 更新時(shí)間:2021年12月16日 08:31:34   作者:青燈夜游  
在本篇文章里小編給大家整理了一篇關(guān)于vue中4個(gè)自定義指令講解及實(shí)例用法,有興趣的朋友們可以跟著學(xué)習(xí)下。

四個(gè)實(shí)用的vue自定義指令

1、v-drag

需求:鼠標(biāo)拖動(dòng)元素

思路:

元素偏移量 = 鼠標(biāo)滑動(dòng)后的坐標(biāo) - 鼠標(biāo)初始點(diǎn)擊元素時(shí)的坐標(biāo) + 初始點(diǎn)擊時(shí)元素距離可視區(qū)域的top、left。
將可視區(qū)域作為邊界,限制在可視區(qū)域里面拖拽?!鞠嚓P(guān)推薦:《vue.js教程》】

代碼:

Vue.directive('drag', {
  inserted(el) {
    let header = el.querySelector('.dialog_header')
    header.style.cssText += ';cursor:move;'
    header.onmousedown = function (e) {
      //獲取當(dāng)前可視區(qū)域?qū)?、?
      let clientWidth = document.documentElement.clientWidth
      let clientHeight = document.documentElement.clientHeight
 
      //獲取自身寬高
      let elWidth = el.getBoundingClientRect().width
      let elHeight = el.getBoundingClientRect().height
 
      //獲取當(dāng)前距離可視區(qū)域的top、left
      let elTop = el.getBoundingClientRect().top
      let elLeft = el.getBoundingClientRect().left
 
      //獲取點(diǎn)擊時(shí)候的坐標(biāo)
      let startX = e.pageX
      let startY = e.pageY
 
      document.onmousemove = function (e) {
        //元素偏移量 = 鼠標(biāo)滑動(dòng)后的坐標(biāo) - 鼠標(biāo)初始點(diǎn)擊元素時(shí)的坐標(biāo) + 初始點(diǎn)擊時(shí)元素距離可視區(qū)域的top、left
        let moveX = e.pageX - startX + elLeft
        let moveY = e.pageY - startY + elTop
 
        //將可視區(qū)域作為邊界,限制在可視區(qū)域里面拖拽
        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

需求:后臺(tái)字段限制了長(zhǎng)度,并且區(qū)分中英文,中文兩個(gè)字節(jié),英文一個(gè)字節(jié);所以輸入框需要限制輸入的字?jǐn)?shù)并且區(qū)分字節(jié)數(shù),且需回顯已輸入的字?jǐn)?shù)。

思路:

一個(gè)字節(jié)的正則/[\x00-\xff]/g

創(chuàng)建包裹字?jǐn)?shù)限制的元素,并定位布局在textarea和input框上

分別計(jì)算輸入的字符一個(gè)字節(jié)的有enLen個(gè),兩個(gè)字節(jié)的有cnLen個(gè);用來后面字符串截?cái)嗵幚?br />

當(dāng)輸入的字?jǐn)?shù)超過限定的字?jǐn)?shù),截?cái)嗵幚?;substr(0,enLen+cnLen)

接口更新了輸入框的值,或者初始化輸入框的值,需要回顯正確的字節(jié)數(shù)

代碼:

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
        }
      }
   
      //更新當(dāng)前輸入框的字節(jié)數(shù)
      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
        }
      }
   
      //更新當(dāng)前輸入框的字節(jié)數(shù)
      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
      }
    }
 
    //創(chuàng)建包裹字?jǐn)?shù)限制的元素,并定位布局在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框不是置灰的狀態(tài)則添加背景顏色
        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
      // 字?jǐn)?shù)限制的盒子插入到el后是最后一個(gè)元素
      el.children[el.children.length-1].innerHTML = val.length + '/' + value
      if(val.length>value){
        let cnLen = 0 //一個(gè)字節(jié)的字?jǐn)?shù)
        let enLen = 0 //兩個(gè)字節(jié)的字?jǐn)?shù)
 
        if(val.match(/[^**]/g) && val.match(/[^**]/g).length){
          enLen = val.match(/[^**]/g).length // 計(jì)算一個(gè)字節(jié)的字?jǐn)?shù)
 
          //一個(gè)字節(jié)兩個(gè)字節(jié)都有的情況
          if((value - val.match(/[^**]/g).length)>0){
            cnLen = Math.floor((value - val.match(/[^**]/g).length)/2)
          }else{
            cnLen = 0
          }
        }else{ //全部?jī)蓚€(gè)字節(jié)的情況
          enLen = 0
          cnLen = Math.floor(value/2)
        }
 
        if(enLen>value){
          enLen = value
        }
 
        //超過限定字節(jié)數(shù)則截取
        el.children[current].value = el.children[current].value.substr(0,enLen+cnLen)
 
        //更新當(dāng)前輸入框的字節(jié)數(shù)
        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

需求:點(diǎn)擊某個(gè)元素(通常是標(biāo)題、副標(biāo)題之類的),動(dòng)畫滾動(dòng)到對(duì)應(yīng)的內(nèi)容塊

思路:

定時(shí)器使用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(){
      // 當(dāng)前元素距離可視區(qū)域頂部的距離
      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

需求:根據(jù)系統(tǒng)角色添加或刪除相應(yīng)元素

代碼:

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(`請(qǐng)檢查指令綁定的表達(dá)式,正確格式例如 v-hasRole="['admin','reviewer']"`)
    }
  }
})

到此這篇關(guān)于vue中4個(gè)自定義指令講解及實(shí)例用法的文章就介紹到這了,更多相關(guān)vue中值得了解的4個(gè)自定義指令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue3中利用Export2Excel將數(shù)據(jù)導(dǎo)出為excel表格

    vue3中利用Export2Excel將數(shù)據(jù)導(dǎo)出為excel表格

    這篇文章主要給大家介紹了關(guān)于vue3中利用Export2Excel將數(shù)據(jù)導(dǎo)出為excel表格的相關(guān)資料,最近項(xiàng)目需要前端來導(dǎo)出Excel操作,所以給大家總結(jié)下,需要的朋友可以參考下
    2023-09-09
  • vue源碼中的檢測(cè)方法的實(shí)現(xiàn)

    vue源碼中的檢測(cè)方法的實(shí)現(xiàn)

    這篇文章主要介紹了vue源碼中的檢測(cè)方法的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • vue請(qǐng)求服務(wù)器數(shù)據(jù)后綁定不上的解決方法

    vue請(qǐng)求服務(wù)器數(shù)據(jù)后綁定不上的解決方法

    今天小編就為大家分享一篇vue請(qǐng)求服務(wù)器數(shù)據(jù)后綁定不上的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vue-cli腳手架初始化項(xiàng)目各個(gè)文件夾用途

    vue-cli腳手架初始化項(xiàng)目各個(gè)文件夾用途

    這篇文章主要介紹了vue-cli腳手架初始化項(xiàng)目各個(gè)文件夾用途,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • vue?實(shí)現(xiàn)彈窗關(guān)閉后刷新效果

    vue?實(shí)現(xiàn)彈窗關(guān)閉后刷新效果

    這篇文章主要介紹了vue?實(shí)現(xiàn)彈窗關(guān)閉后刷新效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 基于Vue 實(shí)現(xiàn)一個(gè)中規(guī)中矩loading組件

    基于Vue 實(shí)現(xiàn)一個(gè)中規(guī)中矩loading組件

    這篇文章主要介紹了基于Vue 實(shí)現(xiàn)一個(gè)中規(guī)中矩loading組件,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04
  • 在vue上使用cesium開發(fā)三維地圖的詳細(xì)過程

    在vue上使用cesium開發(fā)三維地圖的詳細(xì)過程

    這篇文章主要給大家介紹了關(guān)于在vue上使用cesium開發(fā)三維地圖的詳細(xì)過程,Cesium是一個(gè)強(qiáng)大的JavaScript庫,支持三維地理信息展示,并提供了豐富的地理空間數(shù)據(jù)可視化功能,需要的朋友可以參考下
    2023-12-12
  • Vue3+TS+Vite+NaiveUI搭建一個(gè)項(xiàng)目骨架實(shí)現(xiàn)

    Vue3+TS+Vite+NaiveUI搭建一個(gè)項(xiàng)目骨架實(shí)現(xiàn)

    本文主要介紹了Vue3+TS+Vite+NaiveUI搭建一個(gè)項(xiàng)目骨架實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • vue、uniapp實(shí)現(xiàn)組件動(dòng)態(tài)切換效果

    vue、uniapp實(shí)現(xiàn)組件動(dòng)態(tài)切換效果

    在Vue中,通過使用動(dòng)態(tài)組件,我們可以實(shí)現(xiàn)組件的動(dòng)態(tài)切換,從而達(dá)到頁面的動(dòng)態(tài)展示效果,這篇文章主要介紹了vue、uniapp實(shí)現(xiàn)組件動(dòng)態(tài)切換,需要的朋友可以參考下
    2023-10-10
  • vue.js學(xué)習(xí)筆記:如何加載本地json文件

    vue.js學(xué)習(xí)筆記:如何加載本地json文件

    這篇文章主要介紹了vue.js學(xué)習(xí)筆記:如何加載本地json文件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧。
    2017-01-01

最新評(píng)論