先上github地址 https://github.com/gaohan1994... 有空点个赞蛤~~

2018-4-19日更新适配到安卓低版本的插件buggyfill(是我疏忽导致大家以为vw解决方案兼容范围过小,原第六步css-modules改为buggyfill,css-modules顺延为第七步)

2018-4-16日更新css-modules配置,前面步骤不变,可直接跳到第七步。

写在前面的话

在接触到大漠先生牵头开发的vw解决方案之前,我使用的是阿里的第一代适配解决方案 lib-flexible 在使用vw解决方案开发一套H5之后,我真正的被vw的威力所折服。
由于大漠先生只给出了vue-cli的配置方式,并未给出react系列对应脚手架create-react-app配置版本,在看过大漠先生的配置之后,我在create-react-app脚手架生成的项目上进行了一套配置,使得使用react的各位师兄弟也可以使用vw解决方案!
话不多说开工

vue使用方式:《如何在Vue项目中使用vw实现移动端适配》
关于具体如何使用请参考
再聊移动端页面的适配
使用Flexible实现手淘H5页面的终端适配

移动端适配最接近完美的解决方案在react中的使用方式。本文只讲create-react-app创建的项目如何配置,具体每个插件的用途和使用方法请先查阅大漠先生的文章,我相信大漠先生的文章已经讲的很明白。

《如何在Vue项目中使用vw实现移动端适配》

《如何在Vue项目中使用vw实现移动端适配》

《如何在Vue项目中使用vw实现移动端适配》

重要的事情说三遍。一定要先大概看一下大漠先生的文章再往下看,否则可能会一头雾水。

1.创建项目

create-react-app react-vw-layout
cd react-vw-layout
npm start

打开http://localhost:3000/ 可以看到react欢迎页面,第一步成功。

2.打开配置选项

由于react默认隐藏webpack配置需要手动显示。

npm run eject
//Are you sure you want to eject? This action is permanent. (y/N)
y

运行完eject之后项目结构如下

第二步收工,第三部开始配置各种插件。

3.增加配置

安装postCss插件

npm i --save postcss-aspect-ratio-mini postcss-px-to-viewport postcss-write-svg postcss-cssnext postcss-viewport-units cssnano

config/webpack.config.dev.js文件中进行如下修改

1.引入postCss插件

const postcssAspectRatioMini = require('postcss-aspect-ratio-mini');
const postcssPxToViewport = require('postcss-px-to-viewport');
const postcssWriteSvg = require('postcss-write-svg');
const postcssCssnext = require('postcss-cssnext');
const postcssViewportUnits = require('postcss-viewport-units');
const cssnano = require('cssnano');

2.加入postCss配置

加入配置代码位置如下

{test: /\.css$/,use: [require.resolve('style-loader'),{loader: require.resolve('css-loader'),options: {importLoaders: 1,},},{loader: require.resolve('postcss-loader'),options: {// Necessary for external CSS imports to work// https://github.com/facebookincubator/create-react-app/issues/2677ident: 'postcss',plugins: () => [require('postcss-flexbugs-fixes'),autoprefixer({browsers: ['>1%','last 4 versions','Firefox ESR','not ie < 9', // React doesn't support IE8 anyway],flexbox: 'no-2009',}),//加入地点//加入地点//加入地点],},},],
},    

需要加入的代码如下


postcssAspectRatioMini({}),
postcssPxToViewport({ viewportWidth: 750, // (Number) The width of the viewport. viewportHeight: 1334, // (Number) The height of the viewport. unitPrecision: 3, // (Number) The decimal numbers to allow the REM units to grow to. viewportUnit: 'vw', // (String) Expected units. selectorBlackList: ['.ignore', '.hairlines'], // (Array) The selectors to ignore and leave as px. minPixelValue: 1, // (Number) Set the minimum pixel value to replace. mediaQuery: false // (Boolean) Allow px to be converted in media queries.
}),
postcssWriteSvg({utf8: false
}),
postcssCssnext({}),
postcssViewportUnits({}),
cssnano({preset: "advanced", autoprefixer: false, "postcss-zindex": false
})

第三步收工。

4.测试

修改App.js

import React, { Component } from 'react';
import './App.css';class App extends Component {render() {return (<div className="App">hello vw-layout</div>);}
}
export default App;

修改App.css

.App {width: 750px;height: 200px;background: #f27a7a;color: #ffffff;line-height: 200px;text-align: center;
}

重新npm start页面显示如下

可以说是非常OK,剩下最后一个问题,配置生产环境webpack配置文件。

5.配置生产环境webpack.config.js

操作与配置测试环境文件相同先引入插件,在相同的位置配置postCss插件
配置完成后执行npm run build
打开static/css/main.********.css

可以看到已经成功编译,打完收工

6.加入viewport-units-buggyfill配置

这一步不过在大漠先生的文章中或是我自己的项目中都已经配置,系我自己的疏忽忘记写在文章中导致大家以为vw兼容范围小。抱歉!!!

打开public/index.html

首先在<head></head>中引入阿里cdn

<script src="//g.alicdn.com/fdilab/lib3rd/viewport-units-buggyfill/0.6.2/??viewport-units-buggyfill.hacks.min.js,viewport-units-buggyfill.min.js"></script>

body中,加入如下js代码:

 <script>window.onload = function () {window.viewportUnitsBuggyfill.init({hacks: window.viewportUnitsBuggyfillHacks});}
</script>

最终index.html如下

<!DOCTYPE html>
<html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"><meta name="theme-color" content="#000000"><!--manifest.json provides metadata used when your web app is added to thehomescreen on Android. See https://developers.google.com/web/fundamentals/engage-and-retain/web-app-manifest/--><link rel="manifest" href="%PUBLIC_URL%/manifest.json"><link rel="shortcut icon" href="%PUBLIC_URL%/favicon.ico"><!--Notice the use of %PUBLIC_URL% in the tags above.It will be replaced with the URL of the `public` folder during the build.Only files inside the `public` folder can be referenced from the HTML.Unlike "/favicon.ico" or "favicon.ico", "%PUBLIC_URL%/favicon.ico" willwork correctly both with client-side routing and a non-root public URL.Learn how to configure a non-root public URL by running `npm run build`.--><title>React App</title><script src="//g.alicdn.com/fdilab/lib3rd/viewport-units-buggyfill/0.6.2/??viewport-units-buggyfill.hacks.min.js,viewport-units-buggyfill.min.js"></script></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div><!--This HTML file is a template.If you open it directly in the browser, you will see an empty page.You can add webfonts, meta tags, or analytics to this file.The build step will place the bundled scripts into the <body> tag.To begin the development, run `npm start` or `yarn start`.To create a production bundle, use `npm run build` or `yarn build`.--><script>window.onload = function () {window.viewportUnitsBuggyfill.init({hacks: window.viewportUnitsBuggyfillHacks});}</script></body>
</html>

重新执行npm start打开页面发现:

如果遇到img无法显示,则添加全局css

img { content: normal !important;
}

OK配置成功。这样就适配了低版本安卓机型

7.加入css-modules配置

一般的小项目不使用css-modules已经可以hold住了,但是页面多起来还是建议使用css-modules,下面介绍一下用法:

执行npm i --save react-css-modules

App.js文件中引入插件
import CSSModules from 'react-css-modules';

修改css文件的引入方式
import './App.css';修改为import styles from './App.css';

修改引用Css方式
className=>styleName

修改导出方式
export default App=>export default CSSModules(App, styles);

保存,从新执行npm start查看页面发现失败

原因是未打开css import配置,此时import styles from './App.css';该语句并未成功引入css文件。

打开webpack.config.dev.js加入modules: true
找到如下位置

{test: /\.css$/,use: [require.resolve('style-loader'),{loader: require.resolve('css-loader'),options: {//看这里看这里看这里看这里modules: true,importLoaders: 1,},},{loader: require.resolve('postcss-loader'),options: {//.....省略}}],},

保存,再次执行npm start查看页面

成功!但是这个class名太过乱码不适于调试,再次打开webpack.config.dev.js
找到如下位置加入语句localIdentName:'[name]_[local]_[hash:base64:5]'

{test: /\.css$/,use: [require.resolve('style-loader'),{loader: require.resolve('css-loader'),options: {modules: true,importLoaders: 1,//看这里看这里看这里localIdentName: '[name]_[local]_[hash:base64:5]'},},{loader: require.resolve('postcss-loader'),options: {//.....省略}}],},

再次执行npm start查看页面

OJBK大功告成!

最后相同步骤加入到webpack.config.prod.js
执行npm run build 查看打包文件

彳亍吧,OK了。

END.其他想说的话

git地址再发一次,希望有空能帮忙点个赞~谢谢~~!! https://github.com/gaohan1994... 没有配置成功的可以参考一下。尤其是css-modules可能改的地方比较多。

当初看到大漠先生的vw适配方案真的是眼前一亮,在尝试了之后觉得这套方案的生产力非常强悍,其实按照本文进行配置已经可以满足相当一部分项目,除了一点就是没有使用css-modules,当然我自己已经成功配置了css-modules要修改的地方比较多,以后会出一篇文章来再继续分享,同时我是个Typescript重度患者!我极度作死的成功配置了create-react-app typescript versionvw + css-modules版本,现在回想起来配置的那几天真的生不如死。。。各种
踩坑。 等如果有人需要ts + react + vw 解决方案的时候我再写一篇文章吧。
那就到这里了,希望大家使用vw解决方案玩的愉快!

基于react/vue的移动端终极适配方案(更新css-modules配置)相关推荐

  1. 一个基于 React 开发的PC端音乐App

    ?一个基于 React 开发的PC端音乐App. 同时支持 Mac 与 Windows 系统.下载地址 项目使用 electron 作为外壳,webpack 作为打包工具,核心技术包括 React + ...

  2. 谈谈我的移动端rem适配方案

    最近有点怀疑人生,毕竟一个人写前端,有时候会怀疑自己理解的一些东西包括用法有没有符合标准.趁着这阵子闲下来,翻了翻别人的rem适配博客,发现有点绕口,怪自己是个强迫症,啥都要自己去试试结果并从中理解, ...

  3. 超详细的rem+vw移动端屏幕适配方案

    在说具体内容之前,我们必须了解几个概念,就是:Retina屏.物理像素.设备独立像素.设备像素比 在CSS中我们一般使用px作为单位,需要注意的是,CSS样式里面的px和物理像素并不是相等的.CSS中 ...

  4. Vue.js——PC端和移动端样式适配方案

    此方案整合了断点响应式样式,和移动端样式重分配. 前言 最近在学习Vue的项目架构,查询了很多移动端样式适配,整合了一下我自己的适配方案做一个记录,可能不是最好的,但我自己用着还蛮顺手的~欢迎大家补充 ...

  5. 支持动图、一键生成,基于 React 的开源像素绘画应用 —— Pixel Art to CSS

    目录 ​编辑 前言简介--何为React? 基于React的 Pixel Art to CSS 绘画编辑器 示例 效果演示 生成代码 具体操作 其他功能 下载地址 前言简介--何为React? 基于R ...

  6. Android屏幕适配框架-(今日头条终极适配方案)

    2019独角兽企业重金招聘Python工程师标准>>> 在Android开发中,屏幕适配是一个非常头痛的问题,因而为了去进行屏幕适配,作为程序员,是呕心沥血,历经磨难,哈哈 我们之前 ...

  7. vscode怎么自动将px转换成vw_基于react/vue移动端适配之px自动转rem、vw

    作为一名前端开发,在做移动端适配时rem.vw是我们经常用到的单位,但是我们在实际开发过程中需要将设计稿上的px转换成rem,如果手动去计算,将是一个很耗时.费力的过程.这是就需要一个工具可以帮我们自 ...

  8. 基于react/vue开发一个专属于程序员的朋友圈应用

    前言 今天本来想开源自己写的CMS应用的,但是由于五一期间笔者的mac电脑突然崩溃了,所有数据无法恢复,导致部分代码丢失,但庆幸的是cms的打包文件已上传服务器,感兴趣的朋友可以在文末链接中访问查看. ...

  9. react antd confirm content list_基于react/vue开发一个专属于程序员的朋友圈应用

    前言 今天本来想开源自己写的 CMS应用的,但是由于五一期间笔者的 mac电脑突然崩溃了,所有数据无法恢复,导致部分代码丢失,但庆幸的是 cms的打包文件已上传服务器,感兴趣的朋友可以在文末链接中访问 ...

  10. 基于SpringBoot+VUE(PC端+小程序端)的智能在线考试系统毕业设计

    作者主页:编程千纸鹤 作者简介:Java.前端.Python开发多年,做过高程,项目经理,架构师 主要内容:Java项目开发.毕业设计开发.面试技术整理.最新技术分享 收藏点赞不迷路  关注作者有好处 ...

最新文章

  1. OGEngine开源引擎环境搭建
  2. JProfiler9安装 监控Tomcat
  3. Node有什么特点?
  4. access 一亿条数据_操作用户只能看到自己本部门的数据功能
  5. 分布式流控介绍和实现原理
  6. spring-第N篇整合SSM,即Mybatis+Spring+Spring MVC
  7. ASP.Net中控件的EnableViewState属性
  8. 【Urule源码解析1】开源可视化规则引擎
  9. WIN10安装CUDA10 cuDNN
  10. 吞云吐雾,美国电子烟问题,内附FDA的一个隐情
  11. 水果店的售价应该怎么来定,水果店怎样确定价格
  12. matlab仿真电磁波的产生,电磁场与电磁波Matlab仿真
  13. 用flask和html制作个人相册页面,Python编程flask使用页面模版的方法
  14. 【干货】磨金石教育UI快速入门!U设计基础知识整理,新人必备
  15. K线形态识别_双飞乌鸦
  16. 淘宝系统 B2C电子商务系统UML建模 范例
  17. JAVA代码怎样变成软件_怎么使JAVA程序变成可执行程序
  18. OSG三维渲染引擎编程学习之十七:“第二章:OSG数学基础” 之 “2.7 世界坐标系、物体坐标系、摄像机坐标系”
  19. 关于Visual studio 2010运行时闪退问题的解决
  20. SAS软件sid最新

热门文章

  1. android中的ActionBar和ToolBar
  2. javaScript面试题大全
  3. c/c++ linux 进程 fork wait函数
  4. Nginx笔记总结十一:Nginx重写规则指南
  5. python中几个常用的算术函数
  6. hdu4504java
  7. xna中的截屏操作处理
  8. ip-sysctl.txt 文件
  9. 那个清华哈佛双料女学霸, 辞职了
  10. 设计模式学习总结7 - 行为型2 - Command命令模式