中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

vue怎么實現更換主題功能

發布時間:2022-11-07 10:01:00 來源:億速云 閱讀:202 作者:iii 欄目:開發技術

這篇文章主要講解了“vue怎么實現更換主題功能”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“vue怎么實現更換主題功能”吧!

方式一:class切換方式

實現:

在每個需要更換的頁面定義多個class,根據運行時標識動態的切換class名稱實現加載不同的樣式,這種方式較為簡單

優點:

  • 不需要修改構建工具相關

  • 業務開發過程可以實現,沒有限制

  • 支持動態切換

缺點:

  • 邏輯分散耦合在各個頁面,一旦需要修改,涉及修改的頁面較多

  • 代碼需要預先內置,不支持動態顏色修改

方式二:ElementUI的實現

實現:

對主題涉及的顏色使用特殊值

如:UI需要白色#ffffff色值的時候使用一個相近的特征值顏色 如:#fffffe

// 將默認樣式特征值替換為變量,用于多次替換
   getStyleTemplate(data) {
    const colorMap = {
     '#fffffe': 'text_color'
    };
    Object.keys(colorMap).forEach(key => {
     const value = colorMap[key];
     data = data.replace(new RegExp(key, 'ig'), value);
    });
    return data;
   },

在代碼運行時動態獲取到需要修改的顏色值

如: 需要修改#fffffe =》 #ff00ff

// 通過用戶操作或者接口,獲取到要替換的色值
 colors:{
     text_color: '#ff00ff'
    }

查找頁面所有style標簽將其色值#fffffe正則匹配出來,替換為 #ff00ff

// 獲取默認樣式,可以從已加載的 style 中獲取也可以從 css link 獲取
   getIndexStyle() {
    document.querySelectorAll('style').forEach(item=>{
     this.originalStyle += this.getStyleTemplate(item.textContent);
    })
   },
   getCssLink(){
     this.get('./cssPath.css').then(json=>{
       this.originalStyle = this.getStyleTemplate(json.data);
     })
   }

在頁面新加標簽style覆蓋默認值

// 替換默認樣式表,插入 style 標簽覆蓋樣式
   writeNewStyle() {
    let cssText = this.originalStyle;
    log(cssText)
    Object.keys(this.colors).forEach(key => {
     cssText = cssText.replace(new RegExp('(:|\\s+)' + key, 'g'), '$1' + this.colors[key]);
    });
    cssText = cssText.replace(/\n/g,'')
    if (this.originalStylesheetCount === document.styleSheets.length) {
     const style = document.createElement('style');
     style.innerText = cssText;
     document.head.appendChild(style);
    } else {
     document.head.lastChild.innerText = cssText;
    }
   },

優點:

  • 支持動態切換

  • 支持動態色值

  • 不需要內置多份樣式

缺點:

  • 業務開發過程中需要對ui給出的色值重定義,業務開發需要有一定的規則

  • 無法修改背景圖片

  • 無法對懶加載的樣式做處理,需要初始化加載全局所有樣式

const ExtractTextPlugin = require('extract-text-webpack-plugin')

// 抽離css
 module: {
 loaders: [
      {//抽離css 通過link加載
        test: /\.css$/,
        loader: ExtractTextPlugin.extract({ 
        fallback: 'style-loader', 
        use: 'css-loader'
        })
      }
      ...
      
 plugins: [
    new ExtractTextPlugin({ 
    filename: 'css/[name].css'
    allChunks: true // 打包所有頁面css到同一個css 文件
    })
  ]
  • 無法動態修改背景圖片

方式三:編譯時多主題全量構建

實現:

  • 定義多套樣式

  • 構建時將多套樣式主題作為獨立構建入口,構建出主題靜態文件css文件

  • 業務運行時動態加載不同的主題文件

優點:

  • 支持動態切換主題

  • 業務開發樣式分離

  • 編譯時構建性能較好 缺點:

  • 構建工具配置較為復雜,適用單入口應用,對多入口的支持不友好

  • 需要定義全局 less 文件,在入口引入

  • 業務需要額外操作

配合 rel="alternate stylesheet" 可預加載備選主題樣式

方式四: 編譯時選擇性構建

實現:

  • 內置多套皮膚

  • 構建時傳入參數,根據不同的構建參數加載不同的主題樣式文件

優點:

  • 構建工具配置較為簡單,不需要業務做額外操作

  • 多入口應用支持度好

缺點:

  • 不支持動態切換

  • 多個項目需要構建多次,需要構建系統支持

方式五:less動態變量

實現:

  • 修改構建腳本,將所有頁面less文件抽到同一個文件中

  • 不編譯less,頁面直接加載less文件

  • 使用less.js 在客戶端編譯less 文件

less: {
    modifyVars: {},
    javascriptEnabled: true
   }

優點:

  • 支持動態切換

  • 支持動態色值

缺點:

  • 客戶端編譯較耗性能/耗時

  • 需要額外加載less.js mini文件size: 131KB

方式六:css變量

實現:

在需要變化的css屬性定義變量

:root {
 --main-bg-color: pink;
}

body {
 background-color: var(--main-bg-color);
}

在運行時動態的修改變量

document.body.style.setProperty('--primary', '#7F583F');

優點:

  • 瀏覽器原生支持,無需額外操作

  • 支持動態色值

缺點:

  • 低版本兼容性不好 ios Safari 9.3、 android 5、 chrome forAndroid 76

UC、QQ、Baidu 等國內瀏覽器支持度較差

方式七: import動態加載

實現:

  • 業務中預定義多套主題

  • 運行時根據變量動態加載對應主題

if(a){
  import('./thems/a/base.less')
}else if(b){
   import('./thems/b/base.less')
}

優點:

  • 支持動態切換

  • 實現簡單

缺點:

  • 不支持動態色值

  • 需要全局定義多套樣式表

  • 全局定義 class 無法定義變量在 vue style 中引用變量

方式動態切換動態色值支持變量實現復雜度兼容性性能維護性
class切換方式簡單良好良好
ElementUI的實現中等良好一般
編譯時多主題全量構建復雜良好一般
編譯時選擇性構建中等良好良好
less變量復雜良好
css變量中等良好
import動態加載簡單良好良好

注:

  • 動態切換:是否支持在運行時切換皮膚

  • 動態設置:是否支持在運行時動態設置皮膚顏色

  • 支持變量:是否可以再全局定義變量 less 文件,然后在不同的頁面引用 less,依賴其中的變量,還是需要在全局 less 文件里面定義全局 class

  • 實現復雜度: 需要修改的代碼量包括構建工具和業務代碼

  • 兼容性: 主流瀏覽器支持程度

  • 性能:包括代碼的首屏加載的 size、切換的速度、切換的時候會不會有閃動

Vue的優點

Vue具體輕量級框架、簡單易學、雙向數據綁定、組件化、數據和結構的分離、虛擬DOM、運行速度快等優勢,Vue中頁面使用的是局部刷新,不用每次跳轉頁面都要請求所有數據和dom,可以大大提升訪問速度和用戶體驗。

感謝各位的閱讀,以上就是“vue怎么實現更換主題功能”的內容了,經過本文的學習后,相信大家對vue怎么實現更換主題功能這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

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

vue
AI

襄城县| 五原县| 鲁甸县| 页游| 眉山市| 钟山县| 洮南市| 金堂县| 昌图县| 石台县| 昭觉县| 库车县| 清流县| 绵阳市| 区。| 耿马| 四子王旗| 芒康县| 东城区| 集贤县| 和田县| 商南县| 游戏| 瓦房店市| 岳阳县| 霞浦县| 广昌县| 宿松县| 祁东县| 永州市| 靖安县| 卓资县| 广安市| 乌拉特前旗| 怀集县| 浙江省| 成安县| 铜梁县| 新疆| 舟山市| 读书|