成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

vue學(xué)習(xí)組件之路之menu導(dǎo)航菜單

Vixb / 3237人閱讀

摘要:后面就是和定位彈出框一樣類似的操作,在導(dǎo)航菜單里面我并沒有這么做,后面會(huì)改成這樣的吧。一些多層嵌套的位置問題,尚未完成。在顯示的時(shí)候會(huì)有高度抖動(dòng)的問題。里面給某些子組件添加樣式用到了深度作用。

效果盡量仿著element做。
預(yù)覽地址

組件之間的通信

 
        
          
          for Mac
           for Windows
             
        
          
            快速入門
            進(jìn)階配置
            多語言支持
                         
        
 
selected的傳遞

如圖所示,關(guān)于(selected:被選中的那個(gè)item),在menu里面控制,通過watchChild“監(jiān)聽每個(gè)item”,一旦menu-item被點(diǎn)擊便會(huì)觸發(fā)

this.$emit("menuItemUpdate",this.name)

這里menu便會(huì)通過menu-item$emit$on實(shí)現(xiàn)數(shù)據(jù)的傳遞

watchChild(){
                this.items.forEach(vm=>{
                    vm.$on("menuItemUpdate",name=>{
                        this.$emit("update:selected",[name])
                    })
                })
            },

這里的this.items就是收集的每一個(gè)menu-item,這在一開始就已經(jīng)完成了。
要用到依賴注入,這里面子組件menu-item都直接操作menudata,耦合度非常高。

//menu
 provide(){
          return {
              root:this
          }
        }
//menu-item
 inject:["root"],
        created(){
           this.root.addItem(this)
          //.........
        },

然后告訴menu-item你可以被選中了。updated鉤子函數(shù)用作完成這個(gè)任務(wù)再適合不過了

 updated(){
           this.updateChild()
        },
 methods:{
     updateChild(){
              this.items.forEach(vm=>{
                  if(this.selected.indexOf(vm.name)>-1){
                      vm.selected = true
                  }else{
                      vm.selected = false
                  }
              })
          }
 }        
路徑元素的收集

當(dāng)menu-item被選中時(shí),觸發(fā)tellParents函數(shù),收集這條路徑上所有父元素的name,把這個(gè)收集好的數(shù)據(jù)放到selectedArr里面。這個(gè)還可以用來高亮路徑上的父元素。
在click的時(shí)候觸發(fā)onClick函數(shù)

onClick(){
                //...........
                let subFather = this.$parent.$el.classList.contains("x-sub-menu") this.$parent.$el.classList.contains("x-sub-menu")
                let groupFather = this.$parent.$el.classList.contains("x-menu-item-group")
               //..........
                if(subFather||groupFather){
                 //.......
                    this.tellParents(this)
                   //.......
                }else{
                    //.......
                }

            },

tellParents遞歸調(diào)用自身來收集 name


 tellParents(that){
                if(that.$parent.$parent.$options.name==="x-sub-menu" ||that.$parent.$parent.$options.name==="x-menu-item-group"){
                    this.root.selectedArr.unshift(that.$parent.name)
                    this.tellParents(that.$parent)
                }else{
                    this.root.selectedArr.unshift(that.$parent.name)
                    console.log(this.root.selectedArr)
                }
            },

最后就是我希望在menu-item被選中后,可以關(guān)閉路徑的所有彈出框popover。
這同樣需要一個(gè)遞歸遍歷

childClosePopover(){
                if(this.$parent.$options.name==="x-sub-menu"){
                    this.open = false
                    this.$parent.childClosePopover()
                }
            },
自定義主題顏色的實(shí)現(xiàn)

參照了一下Menu Attribute。
這里的文字顏色和圖標(biāo)顏色是同步的,
hover的css效果和active的一樣

text-color文字顏色 。

active-color被選中顏色。

back-ground-color正常背景色 。

active-back-ground-color被選中的背景色 。

數(shù)據(jù)傳遞

如圖所示的紫色的路線,通過遞歸遍歷通知menu樹里面的每一個(gè)分支,改變顏色,是否垂直,disabled等等。
大部分添加的功能都在這條線上實(shí)現(xiàn)通信。

js控制顏色的更改
watch:{
            selected(){
                if(this.selected&&........{
                    this.$refs.item.style.backgroundColor = ........
                    this.$refs.item.style.color = .........
                    //...........
                }else{
                  //............
                }
            }
        }
彈出框的問題

element對(duì)彈出框的操作是以在body上添加子節(jié)點(diǎn)的方式。這樣子最直接的就是避免了可能存在overflow:hideen的問題。
后面的定位只需要用js來完成就行了,還要考慮到scroll的問題。

最麻煩的地方在于動(dòng)畫過渡上,單純的用css會(huì)有彈出框回到原點(diǎn)的問題。
這里就需要用到
javascript鉤子。
官網(wǎng)在這上面的說的很明確,但是實(shí)現(xiàn)過程中也踩了一些坑

動(dòng)畫瞬間完成的問題,這在官網(wǎng)上的解釋時(shí)只用JavaScript做過渡的時(shí)候(沒用css)的情況下動(dòng)畫會(huì)瞬間完成,要使用done。之后試了并沒有用。這里并不是只用JavaScript做過渡的。之后想了一下,既然beforeEnterenter瞬間就執(zhí)行了,并沒有動(dòng)畫的事件間隔,為什么不自己加一個(gè) settimeout呢,問題就解決了,可能這種解決方法并不是很好。這里不用$nextTick的原因

  enter(el) {
    setTimeout(()=>{
      //.....
      })
    },

鉤子中設(shè)置的一些額外的css屬性要在afterEnter改回來啊,其中就例如overflow:hiddenheight,導(dǎo)致在vertical垂直面板上彈出框不會(huì)撐開父元素的問題。

 afterLeave(el){
              el.style.overflow = ""
              if(this.vertical){
                  el.style.height=""
              }
          },

后面就是和定位彈出框一樣類似的js操作,在menu導(dǎo)航菜單里面我并沒有這么做,后面會(huì)改成這樣的吧。

 beforeEnter(el) {
                el.style.position= "absolute"
                el.style.transform=.......
                //.........
          },
  
   enter(el) {
             //......
          },
處理一些細(xì)枝末節(jié)的問題

hover觸發(fā)和click觸發(fā)

彈出框移出消失的時(shí)間控制和動(dòng)畫抖動(dòng)。

高亮線條只在一級(jí)子組件中存在

menu-item-group組件的添加,其實(shí)只是作為一個(gè)中轉(zhuǎn)站而已,無非是拷貝一些函數(shù)。

一些多層嵌套的位置問題,尚未完成。

遇到的一些css問題

橫版里面active下面的亮條顯示,一開始就是設(shè)置menu-item里面的border-bottom,因?yàn)橥瑫r(shí)設(shè)置了transition。在顯示的時(shí)候會(huì)有高度抖動(dòng)的問題。后來改用偽類完成,不過在自定義顏色的時(shí)候非常麻煩。這個(gè)方法也放棄了。最后只有在下面加一個(gè)div代替border-bottom作為高亮線條,方法雖然很蠢,但是有效。

scoped里面給某些子組件添加css樣式用到了 /deep/深度作用。

簡單的總結(jié)?

其實(shí)以這種顯而易見的數(shù)據(jù)流作為基礎(chǔ),多增加一些功能無非是函數(shù)的添加和css的修改。找bug和維護(hù)也是相對(duì)比較輕松的。最后您如果覺得還不錯(cuò)的話,給我的項(xiàng)目一個(gè)star想必也是極好的。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/117573.html

相關(guān)文章

  • vue學(xué)習(xí)組件menu導(dǎo)航菜單

    摘要:后面就是和定位彈出框一樣類似的操作,在導(dǎo)航菜單里面我并沒有這么做,后面會(huì)改成這樣的吧。一些多層嵌套的位置問題,尚未完成。在顯示的時(shí)候會(huì)有高度抖動(dòng)的問題。里面給某些子組件添加樣式用到了深度作用。 效果盡量仿著element做。預(yù)覽地址 組件之間的通信 showImg(https://segmentfault.com/img/remote/1460000018614516?w=788&h=...

    el09xccxy 評(píng)論0 收藏0
  • CSS學(xué)習(xí)筆記(九) 界面組件導(dǎo)航菜單

    摘要:為了讓包圍列表項(xiàng),沒有使用,而是使用了,是因?yàn)榍罢邥?huì)導(dǎo)致后來添加到下拉菜單中的子菜單無法顯示它們最終會(huì)顯示在父元素的外面,結(jié)果會(huì)導(dǎo)致溢出而被隱藏。它與父元素之間的間隙,實(shí)際上下拉菜單中第一個(gè)鏈接的邊框。 菜單由一組鏈接組成。用 HTML 中的列表元素(ul 或 ol)來分組鏈接不僅符合邏輯,而且即使沒有額外的 CSS 也能適當(dāng)顯示鏈接的層次。默認(rèn)情況下,由于列表(li)是塊級(jí)元素...

    pingink 評(píng)論0 收藏0
  • CSS代碼重構(gòu)與優(yōu)化

    摘要:代碼重構(gòu)的目的我們寫代碼時(shí),不僅僅只是完成頁面設(shè)計(jì)的效果,還應(yīng)該讓代碼易于管理,維護(hù)。命名與備注命名是提高代碼可讀性的第一步,也是及其重要的一步。 寫CSS的同學(xué)們往往會(huì)體會(huì)到,隨著項(xiàng)目規(guī)模的增加,項(xiàng)目中的CSS代碼也會(huì)越來越多,如果沒有及時(shí)對(duì)CSS代碼進(jìn)行維護(hù),CSS代碼不斷會(huì)越來越多。CSS代碼交錯(cuò)復(fù)雜,像一張龐大的蜘蛛網(wǎng)分布在網(wǎng)站的各個(gè)位置,你不知道修改這行代碼會(huì)有什么影響,所以...

    fou7 評(píng)論0 收藏0
  • CSS代碼重構(gòu)與優(yōu)化

    摘要:代碼重構(gòu)的目的我們寫代碼時(shí),不僅僅只是完成頁面設(shè)計(jì)的效果,還應(yīng)該讓代碼易于管理,維護(hù)。命名與備注命名是提高代碼可讀性的第一步,也是及其重要的一步。 寫CSS的同學(xué)們往往會(huì)體會(huì)到,隨著項(xiàng)目規(guī)模的增加,項(xiàng)目中的CSS代碼也會(huì)越來越多,如果沒有及時(shí)對(duì)CSS代碼進(jìn)行維護(hù),CSS代碼不斷會(huì)越來越多。CSS代碼交錯(cuò)復(fù)雜,像一張龐大的蜘蛛網(wǎng)分布在網(wǎng)站的各個(gè)位置,你不知道修改這行代碼會(huì)有什么影響,所以...

    不知名網(wǎng)友 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<