欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解基于Vue/React項(xiàng)目的移動(dòng)端適配方案

 更新時(shí)間:2019年08月23日 10:45:01   作者:前端小黑  
這篇文章主要介紹了詳解基于Vue/React項(xiàng)目的移動(dòng)端適配方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

本文的目標(biāo)是通過(guò)下文介紹的適配方案,使用vue或react開發(fā)移動(dòng)端及H5的時(shí)候,不需要再關(guān)心移動(dòng)設(shè)備的大小,只需要按照固定設(shè)計(jì)稿的px值布局,提升開發(fā)效率。

下文給出了本人分別使用create-react-app搭建的react(create-react-app)項(xiàng)目和使用vue-cli 2.x 搭建的vue項(xiàng)目中的 親測(cè)可用 配置方案。

px2rem或postcss-px2rem

  • 在移動(dòng)端中,為了設(shè)配不同的設(shè)備,通常使用rem來(lái)做適配。
  • rem是通過(guò)根元素進(jìn)行適配的,網(wǎng)頁(yè)中的根元素指的是<html>,我們通過(guò)設(shè)置<html>的字體大小就可以控制 rem 的大小(1rem = 1根元素字體大?。?/li>
  • 可見,只要我們根據(jù)不同屏幕(使用css媒體查詢或js)設(shè)定好根元素<html>的字體大小,其他已經(jīng)使用了rem單位的元素就會(huì)自適應(yīng)顯示相應(yīng)的尺寸。
  • 設(shè)計(jì)稿一般是按照一種特定設(shè)備型號(hào)(如iphone6)為基礎(chǔ)且以px單位來(lái)定義樣式,為了讓設(shè)計(jì)稿能夠通用在不同的設(shè)備型號(hào)中,則存在著從px到rem的繁瑣計(jì)算轉(zhuǎn)化過(guò)程,因此需要更加科學(xué)的方式來(lái)使用rem單位。
  • px2rem或postcss-px2rem的原理:將css中px編譯為rem,配合js根據(jù)不同手機(jī)型號(hào)計(jì)算出dpr的值,修改<meta>的viewport值和置<html>的font-size。

項(xiàng)目中的使用

recat項(xiàng)目配置postcss-px2rem

首先,我們使用 react 的腳手架 create-react-app 初始化一個(gè) webpack 項(xiàng)目(前提是已經(jīng)安裝過(guò)create-react-app,具體不再闡述)。

create-react-app my-app

暴露webpack配置,即 react-scripts 包:

yarn eject

使用yarn 安裝項(xiàng)目所需依賴后,安裝 lib-flexible 、 postcss-px2rem 和 postcss-loader:

yarn add postcss-px2rem lib-flexible 
yarn add postcss-loader --dev

在入口頁(yè)面 index.html 中設(shè)置<meta>標(biāo)簽:

<meta name="viewport" content="width=device-width,inital-scale=1.0,
  maximum-scale=1.0,minimum-scale=1.0,user-scalable=no">

然后在項(xiàng)目入口文件 index.js 中引入 lib-flexible:

import 'lib-flexible';

接著,在項(xiàng)目config目錄下的 webpack.config.js 中引入 postcss-px2rem :

const px2rem = require('postcss-px2rem')

同時(shí),在 webpack.config.js 的 postcss-loader loader里面添加 :

{
    loader: require.resolve('postcss-loader'),
    options: {
     /* 省略代碼... */
     plugins: () => [
      require('postcss-flexbugs-fixes'),
      require('postcss-preset-env')({
       autoprefixer: {
        flexbox: 'no-2009',
       },
       stage: 3,
      }),
      px2rem({remUnit: 37.5}), // 添加的內(nèi)容
      /* 省略代碼... */
     ],
     sourceMap: isEnvProduction && shouldUseSourceMap,
    },
   },

最后,使用 yarn start 重啟項(xiàng)目,則會(huì)發(fā)現(xiàn)項(xiàng)目中的postcss-px2rem配置完成。

vue項(xiàng)目配置px2rem

首先,我們使用 vue 的腳手架 vue-cli 初始化一個(gè) webpack 項(xiàng)目(前提是已經(jīng)安裝過(guò)vue-cli,具體不再闡述),一些選項(xiàng)根據(jù)自己項(xiàng)目需要選擇。

vue init webpack my-app

命令執(zhí)行之后,會(huì)在當(dāng)前目錄生成一個(gè)以“my-app”命名的項(xiàng)目文件夾。進(jìn)入項(xiàng)目目錄:

cd my-app

使用yarn 安裝項(xiàng)目所需依賴后,安裝 lib-flexible 和  px2rem-loader:

yarn add lib-flexible
yarn add px2rem-loader --dev

在入口頁(yè)面 index.html 中設(shè)置<meta>標(biāo)簽:

<meta name="viewport" content="width=device-width,inital-scale=1.0,
  maximum-scale=1.0,minimum-scale=1.0,user-scalable=no">

然后在項(xiàng)目入口文件 main.js 中引入 lib-flexible:

import 'lib-flexible/flexible.js';

同時(shí),在項(xiàng)目build目錄下的 utils.js 中,將px2rem-loader 添加到cssLoaders中。通過(guò)搜索找到 generateLoaders 方法,在這里添加:

exports.cssLoaders = function (options) {
 /* 省略代碼塊 */

 const cssLoader = {
  /* 省略代碼塊 */
 }

 /* 添加的代碼塊 */
 const px2remLoader = {
  loader: 'px2rem-loader',
  options: {
   remUnit: 37.5 // 基準(zhǔn)大小 baseSize,設(shè)計(jì)稿寬度/10
  }
 }
 /* 添加的代碼塊 */
 
 // generate loader string to be used with extract text plugin
 function generateLoaders (loader, loaderOptions) {
  const loaders = [cssLoader, px2remLoader] // 添加px2remLoader
  if (loader) {
   /* 省略代碼塊 */
  }

  /* 省略代碼塊 */
}

最后,使用 yarn dev 重啟項(xiàng)目,會(huì)發(fā)現(xiàn)自己設(shè)置的px被轉(zhuǎn)為rem 了。

適用情況 & 不適用情況

以上實(shí)現(xiàn)轉(zhuǎn)換適用于:
(1)vue 組件中編寫的<style></style>下的css。
(2)從 react 項(xiàng)目的 index.js 或者 vue 項(xiàng)目的 main.js 中通過(guò)import ‘../../static/css/reset.css'引入css。
(3)在 vue 組件的<script type=”text/ecmascript-6″>import ‘../../static/css/reset.css'</script>中引入css。

另外的情況不適用:
(1)在 vue 組件的<style></style>中通過(guò)@import “../../static/css/reset.css (可考慮上面(2)、(3)的形式引入)。
(2)外部樣式:<link rel=”stylesheet” href=”static/css/reset.css”>。
(3)元素內(nèi)部樣式:style="height: 417px; width: 550px;"。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue2.0 兄弟組件(平級(jí))通訊的實(shí)現(xiàn)代碼

    vue2.0 兄弟組件(平級(jí))通訊的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue2.0 兄弟組件(平級(jí))通訊的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • vue源碼入口文件分析(推薦)

    vue源碼入口文件分析(推薦)

    這篇文章主要介紹了vue源碼入口文件分析(推薦),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • vue實(shí)現(xiàn)無(wú)縫輪播效果(跑馬燈)

    vue實(shí)現(xiàn)無(wú)縫輪播效果(跑馬燈)

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)無(wú)縫輪播效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • JavaScript之Vue.js【入門基礎(chǔ)】

    JavaScript之Vue.js【入門基礎(chǔ)】

    本文主要介紹一下Vue.js并附上在Node.js環(huán)境下搭建一個(gè)簡(jiǎn)單的Demo實(shí)例代碼。條理清晰,有助于閱讀和理解。有需要的朋友可以看下
    2016-12-12
  • Vue2中compiler和runtime模式報(bào)錯(cuò)template compiler is not available

    Vue2中compiler和runtime模式報(bào)錯(cuò)template compiler is 

    本文主要介紹了Vue2中compiler和runtime模式報(bào)錯(cuò)template compiler is not available,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Vue使用openlayers實(shí)現(xiàn)繪制圓形和多邊形

    Vue使用openlayers實(shí)現(xiàn)繪制圓形和多邊形

    這篇文章主要為大家詳細(xì)介紹了Vue如何使用openlayers實(shí)現(xiàn)繪制圓形和多邊形,文中的示例代碼講解詳細(xì),感興趣的小伙伴快跟隨小編一起動(dòng)手嘗試一下
    2022-06-06
  • 對(duì)vue 鍵盤回車事件的實(shí)例講解

    對(duì)vue 鍵盤回車事件的實(shí)例講解

    今天小編就為大家分享一篇對(duì)vue 鍵盤回車事件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • vue 組件數(shù)據(jù)加載解析順序的詳細(xì)代碼

    vue 組件數(shù)據(jù)加載解析順序的詳細(xì)代碼

    Vue.js的解析順序可以概括為:模板編譯、組件創(chuàng)建、數(shù)據(jù)渲染、事件處理和生命周期鉤子函數(shù)執(zhí)行,接下來(lái)通過(guò)本文給大家介紹vue 組件數(shù)據(jù)加載解析順序的完整代碼,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • vue3.0搭配.net core實(shí)現(xiàn)文件上傳組件

    vue3.0搭配.net core實(shí)現(xiàn)文件上傳組件

    這篇文章主要介紹了vue3.0搭配.net core實(shí)現(xiàn)文件上傳組件,幫助大家開發(fā)Web應(yīng)用程序,完成需求,感興趣的朋友可以了解下
    2020-10-10
  • Vue.js添加組件操作示例

    Vue.js添加組件操作示例

    這篇文章主要介紹了Vue.js添加組件操作,結(jié)合實(shí)例形式分析了vue.js組件的注冊(cè)、調(diào)用相關(guān)操作技巧,需要的朋友可以參考下
    2018-06-06

最新評(píng)論