首頁  >  文章  >  web前端  >  vue.js怎麼實作行動端適配

vue.js怎麼實作行動端適配

coldplay.xixi
coldplay.xixi原創
2020-11-11 11:06:013522瀏覽

vue.js實作行動端適配的方法:1、使用rem佈局,在主入口【index.html】,【

】標籤內加入相關JS程式碼;2、使用【lib -flexible】插件實現。

vue.js怎麼實作行動端適配

本教學操作環境:windows7系統、vue2.9版,此方法適用於所有品牌電腦。

【相關文章推薦:vue.js

#vue.js實作行動裝置適配的方法:

一、方法一:rem 佈局

在主入口:index.html,

標籤內新增如下JS 程式碼:(實作在標準375px寬度適配下,100px = 1rem。)
  <script>
    (function () {
      // 在标准 375px 适配下,100px = 1rem;
      var baseFontSize = 100;  
      var baseWidth = 375;
      var set = function () {
        var clientWidth = document.documentElement.clientWidth || window.innerWidth;
        var rem = 100;
        if (clientWidth != baseWidth) {
          rem = Math.floor(clientWidth / baseWidth * baseFontSize);
        }
        document.querySelector(&#39;html&#39;).style.fontSize = rem + &#39;px&#39;;
      }
      set();
      window.addEventListener(&#39;resize&#39;, set);
    }());
   
  </script>

二、方法二:lib-flexible 外掛實作

##1、安裝外掛

npm i lib-flexible --save        // 载lib-flexible
npm install px2rem-loader        // 安装px2rem-loader

2、在main .js中引入lib-flexible

import &#39;lib-flexible/flexible&#39;

3、在index.html 中加入:移動適配meta標籤

<meta name="viewport" content="width=device-width,initial-scale=1.0">
//注意这两个的区别,建议添加下面的meta,反正点击输入框,页面自动缩放
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">

4、更改配置

在build/util. js 中如下兩更改

(1)、將px2rem-loader加入cssLoaders中

const cssLoader = {
    loader: &#39;css-loader&#39;,
    options: {
      minimize: process.env.NODE_ENV === &#39;production&#39;,
      sourceMap: options.sourceMap
    }
  }
  const px2remLoader = {
    loader: &#39;px2rem-loader&#39;,
    options: {
      //一般设置75
      remUnit: 35
    }
  }

(2)、在generateLoaders方法中加入px2remLoader

  function generateLoaders(loader, loaderOptions) {
    const loaders = options.usePostCSS ? [cssLoader, postcssLoader,px2remLoader] : [cssLoader,px2remLoader]
    if (loader) {
      loaders.push({
        loader: loader + &#39;-loader&#39;,
        options: Object.assign({}, loaderOptions, {
          sourceMap: options.sourceMap
        })
      })
    }
    // Extract CSS when that option is specified
    // (which is the case during production build)
    if (options.extract) {
      return ExtractTextPlugin.extract({
        use: loaders,
        fallback: &#39;vue-style-loader&#39;
      })
    } else {
      return [&#39;vue-style-loader&#39;].concat(loaders)
    }
  }

總結要修改的地方

vue.js怎麼實作行動端適配

5、重啟

npm run dev  // 重新執行

這裡要注意:

1、 lib-flexible:是rem 的適配插件。 (例:750px == 10rem)

2、px2rem-loader :是為了方便在書寫CSS時,輸入 px 會 自動轉為 rem。

3、有時 用 ‘px2rem-loader ’ 插件,發現 rem 轉換不正確。可能是開發工具設定了其他的插件轉換,將其他的插件轉換設定為想要的轉換就行。 【我就遇過,巨坑。 。 。 】

相關免費學習推薦:JavaScript(影片)

#

以上是vue.js怎麼實作行動端適配的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn