91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

elementPlus修改主題色及皮膚設置的方法是什么

發布時間:2023-05-06 17:31:54 來源:億速云 閱讀:619 作者:iii 欄目:開發技術

本篇內容介紹了“elementPlus修改主題色及皮膚設置的方法是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

    elementPlus修改主題色以及皮膚設置

    修改主題色

    <el-color-picker style=“margin-top:20px” v-model=“systeamColor” @change=“colorChange” />

    采用element顏色選擇的組件

    // 變量前綴
    colorChange(e) {
        // e就是選擇了的顏色
        const pre = "--el-color-primary";
        // 白色混合色
        const mixWhite = "#ffffff";
        // 黑色混合色
        const mixBlack = "#000000";
        const el = document.documentElement;
        el.style.setProperty(pre, e);
        // 這里是覆蓋原有顏色的核心代碼
        for (let i = 1; i < 10; i += 1) {
          el.style.setProperty(`${pre}-light-${i}`, mix(e, mixWhite, i * 0.1));
        }
        el.style.setProperty("--el-color-primary-dark", mix(e, mixBlack, 0.1));
    }

    系統皮膚

    通過提前定義好各種皮膚風格

    通過vue的store以及localStorage去動態修改

    同時代碼中要使用變量方式引入store中的主題顏色

    elementPlus修改主題顏色(含暗夜模式切換)

    elementPlus修改主題色及皮膚設置的方法是什么

    直接調用 setThemeColor(color) 函數,color 為傳入的主題顏色

    export function setThemeColor(color) {
      const el = document.documentElement;
      const body = document.querySelector("body");
      // const nprogress = document.querySelector("#nprogress .bar");
      // console.log(nprogress)
      el.style.setProperty("--el-color-primary", color);
      body.style.setProperty("--van-primary-color", color);
      // nprogress.style.setProperty("background", color);
      // 此行判斷是否為白天/暗夜模式,可根據自身業務調整代碼
      let mixColor = Store.state.settings.sideTheme.split("-")[1] === "light" ? "#ffffff" : "#000000"; 
      // 此行判斷是否為白天/暗夜模式,可根據自身業務調整代碼
      for (let i = 1; i < 10; i++) {
        el.style.setProperty(`--el-color-primary-light-${i}`, colourBlend(color, mixColor, i / 10));
        el.style.setProperty(`--el-color-primary-dark-${i}`, colourBlend(color, mixColor, i / 10));
      }
      el.style.setProperty(`--el-color-primary-dark-2`, colourBlend(color, mixColor, 0.2));
    
    }
    
    export function colourBlend(c1, c2, ratio) {
      ratio = Math.max(Math.min(Number(ratio), 1), 0)
      let r1 = parseInt(c1.substring(1, 3), 16)
      let g1 = parseInt(c1.substring(3, 5), 16)
      let b1 = parseInt(c1.substring(5, 7), 16)
      let r2 = parseInt(c2.substring(1, 3), 16)
      let g2 = parseInt(c2.substring(3, 5), 16)
      let b2 = parseInt(c2.substring(5, 7), 16)
      let r = Math.round(r1 * (1 - ratio) + r2 * ratio)
      let g = Math.round(g1 * (1 - ratio) + g2 * ratio)
      let b = Math.round(b1 * (1 - ratio) + b2 * ratio)
      r = ('0' + (r || 0).toString(16)).slice(-2)
      g = ('0' + (g || 0).toString(16)).slice(-2)
      b = ('0' + (b || 0).toString(16)).slice(-2)
      return '#' + r + g + b
    }

    “elementPlus修改主題色及皮膚設置的方法是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    唐河县| 卢湾区| 柘城县| 金秀| 新竹市| 司法| 乌拉特中旗| 汉寿县| 文成县| 扎兰屯市| 玛多县| 龙州县| 徐水县| 东源县| 唐山市| 伊川县| 柳江县| 浦县| 宁明县| 台北市| 阿尔山市| 永州市| 巴塘县| 台北县| 简阳市| 横山县| 罗江县| 淮滨县| 泗洪县| 多伦县| 阳城县| 新竹市| 安阳县| 搜索| 沙洋县| 平阳县| 桂林市| 六安市| 比如县| 荥阳市| 贵德县|