IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> nginx适配杂谈 -> 正文阅读

[系统运维]nginx适配杂谈

适配问题

说起适配,就不得不提到“ 响应式 ”。而说起响应式,可能很多人下意识就会脱口而出:css @media媒体查询
可能还有些人会进一步说出:“利用css的em、rem单位”。

是的,但是你有没有想过一个问题:emrem是根据px计算得来的;而media又“足够复杂” —— 放在一般的项目中还好,如果将css自适应放到淘宝、京东这种极度复杂的场景下,就显得有些束缚了:
因为我们知道,元素大小、位置甚至颜色等的改变都会引起回流重绘!导致页面重新渲染…这对性能是不友好的。

rem来说,按照 750 宽设计稿基准,rem 的方案为 (尺寸 / (750/等份) ) * html font size

css单位

上面说到emrem是响应式中的一大助力。其实css响应式中还可以用vwvhvm来实现。这几个单位也是比较常用的几个。但是它们都是有缺点的:

使用px单位

  1. px看似是固定值,但在不同的设备上展现的却是不同的像素。
  2. 带来理解成本,需理解此时的 px 所代替的含义,此时的 px 其实为相对单位。
  3. 不利于后续升级
    • 替换成到其他适配方案。
    • 设计稿基准值变化。

使用 vw 单位

  1. 视窗单位,依赖视口大小;无法单独使用在响应式中(需结合rem等单位进行控制子级)。
  2. 带来理解成本,需理解此时的 vw 所代替的含义。
  3. 目前设计稿采用的是像素单位,开发时需将 px 转换为 vw,会出现无法除尽的浮点数。
  4. 不利于后续升级。

使用 em / rem 单位

  1. 目前设计稿采用的是像素单位,开发时需按照指定的等份将 px 转换为 em / rem。不利于等份的统一管理。
  2. 不利于后续升级。
  3. 兼容性:IE6-8不支持

背景:rpx

在笔者所在的公司有一套内部的“基础库”。里面有一个单位让我非常感兴趣 —— rpx。是一个模仿微信小程序自适应单位的。
开发手册上大概是这么写的:
在你使用rpx时,内部利用 CSS 插件(postcss 插件)将 rpx 单位转换为 rem,使用 vw 单位替代 flexible ,结合 media query 适配指定设备。

将 rpx 单位转换为 rem 单位,以 750px 设计稿为基准,转换公式为:原始像素尺寸(rpx) / 100

其实内部还是非常麻烦的。

另一个背景:淘宝

tbwhy

可以看到,淘宝网的页面并不是响应式的(你刷新后相当于是换了个设备重新打开此网页),而是在 PC 和 移动端适配的结果 —— 两套页面,根据环境决定使用不同方案。
它虽然不像响应式那样流畅和足够舒适,但是确实非常方便!

这种方式是由服务器配置实现的。它的关键在于:服务器监控当前环境,如果是 PC 端,则展示一套页面;如果是移动端,则展示另一套。(如果你还想进一步细分,比如 Android 和苹果,也可以再去匹配)
这时,一个轻量高性能的服务器 —— nginx就进入了我的视线!

nginx实现网页适配

首先,我们要在项目目录下同级建立两个文件夹 —— 分别表示pc和移动端:

mkdir pc
mkdir mobile

然后将两套页面代码分别放入两个文件夹下。我们假定html文件名都是index.html

然后回到 nginx 服务器根目录的 etc/nginx/conf.d文件夹下:

cd etc/nginx/conf.d

建立一个配置文件:

vim shipei.conf
server{
     listen 80;   # 监听端口
     server_name nginx2.jspang.com; # 域名
     location / { # 控制访问网站的路径
     	# root是最上层目录的定义,文件的绝对路径等于 root+location
      	root /usr/share/nginx/pc;
      	if (!!($http_user_agent ~* /AppleWebKit.*Mobile.*/)) {
        	root /usr/share/nginx/mobile;
      	}
      	# 在前后端分离的基础上,通过Nginx配置,指定网站初始页。
      	index index.html;
     }
}

!!($http_user_agent ~* /AppleWebKit.*Mobile.*/)这里是正则表达式,$http_user_agent是 nginx 内置指令,表示当前的user-agent头。
这里其实也是借鉴了笔者所在公司内部基础库中的一个方法。其实if里还可以这么写:$http_user_agent ~* ' Android | webOS | iPhone| iPad | BlackBerry ')

然后搭配上 viewport 在没有达到页面替换时机时进行缩放:

<meta name="viewport" content="width=320,maximum-scale=1.3,user-scalable=no">

天猫的web app的首页就是采用这种方式去做的,以320宽度为基准,进行缩放,最大缩放为320*1.3 = 416。基本缩放到416都就可以兼容到iphone6 plus的屏幕了,简单粗暴、又高效。

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-07-09 17:42:56  更:2021-07-09 17:43:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 9:51:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码