响应式布局之viewport-超级简单

文章介绍了如何利用viewport和postcss-px-to-viewport插件在Vite环境中简化CSS响应式布局的实现,通过在vite.config.js中配置插件,将px单位转换为vw,从而实现根据浏览器大小变化的动态布局。在不同屏幕尺寸下,布局能够自适应调整。
摘要由CSDN通过智能技术生成

之前文章CSS布局之详解_故里2130的博客-CSDN博客

上面的文章可以实现响应式布局,根据浏览器的大小变化而变化,但是相对于viewport来说,之前的还是有点复杂,而使用viewport更加的简单。

当我们使用amfe-flexible的时候,细心的同学已经发现了,提示我们使用viewport,那么接下来,我们就演示使用viewport。

1. 官网介绍

postcss-px-to-viewport/README_CN.md at master · evrone/postcss-px-to-viewport · GitHub

多的就不说了,但是要补充一点,最重要的是: 使用vite创建和官网不一样,不需要创建postcss.config.js,直接在vite.config.js中创建就行了,或者创建postcss.config.js后,必须在vite.config.js中引用。

2.安装

npm install postcss-px-to-viewport

安装成功标志 

3.在vite.config.js中增加代码

import {
	defineConfig
} from 'vite'
import vue from '@vitejs/plugin-vue'

import pxtovw from 'postcss-px-to-viewport'

const loder_pxtovw = pxtovw({
	//这里是设计稿宽度 自己修改
	unitToConvert: 'px', // 需要转换的单位,默认为"px"
	viewportWidth: 1600, // 设计稿的视口宽度
	unitPrecision: 5, // 单位转换后保留的精度
	propList: ['*'], // 能转化为vw的属性列表
	viewportUnit: 'vw', // 希望使用的视口单位
	fontViewportUnit: 'vw', // 字体使用的视口单位
	selectorBlackList: [], // 需要忽略的CSS选择器,不会转为视口单位,使用原有的px等单位。
	minPixelValue: 1, // 设置最小的转换数值,如果为1的话,只有大于1的值会被转换
	mediaQuery: false, // 媒体查询里的单位是否需要转换单位
	replace: true, //  是否直接更换属性值,而不添加备用属性
	exclude: undefined, // 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件
	include: undefined, // 如果设置了include,那将只有匹配到的文件才会被转换
	landscape: false, // 是否添加根据 landscapeWidth 生成的媒体查询条件 @media (orientation: landscape)
	landscapeUnit: 'vw', // 横屏时使用的单位
	landscapeWidth: 1600 // 横屏时使用的视口宽度
})
export default defineConfig({
	plugins: [vue()],
	css: {
		postcss: {
			plugins: [loder_pxtovw] //加载插件
		}
	}
})

4.创建vue代码

<template>
	<div>123
	</div>
	<el-row class="header">
		<el-col :span="24">
			<span>名称:</span>
			<el-input placeholder="请输入名称" style="width: 300px;" />
			<el-button type="primary" style="margin-left: 20px;">查询</el-button>
			<el-button type="primary" style="margin-left: 200px">
				新增
			</el-button>
			<el-button type="primary">
				刷新
			</el-button>
		</el-col>
	</el-row>
</template>
<style scoped>
	div {
		background-color: red;
		height: 200px;
		width: 100px;
	}

	.header {
		background-color: aqua;
		height: 400px;
		width: 600px;
	}
</style>

5.运行效果

现在随便拖动浏览器的大小,界面的布局根据浏览器的变化而变化,和之前文章的效果一样。

 

6.补充说明:

1.当我们设置1600的时候,表示在1600px的电脑上开发代码 

那么代码的大小,就是实际的大小,必须是这里的400px,600px

效果就是:

1600px的电脑效果,宽度就是实际值600

1920px的电脑效果,宽度响应式变大了

2. 当我们设置1920的时候,表示在1920px的电脑上开发代码 

那么代码的大小,就是实际的大小,必须是这里的400px,600px

效果就是:

1920px的电脑效果,宽度就是实际值600

1600px的电脑效果,宽度响应式变小了

来源:

响应式布局之viewport-超级简单_vue viewport-CSDN博客 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Viewport 是指浏览器窗口中用于显示网页的区域,而 viewport 响应式布局则是指根据不同的设备屏幕大小,动态改变 viewport 的大小以适应不同的屏幕大小,从而实现响应式布局。具体实现如下: 1. 设置 viewport 的 meta 标签 在 HTML 文件头部添加以下 meta 标签,用于指定 viewport 的大小和缩放比例: ```html <meta name="viewport" content="width=device-width, initial-scale=1.0"> ``` 其中 `width=device-width` 表示 viewport 的宽度为设备的宽度,`initial-scale=1.0` 表示初始缩放比例为 1。 2. 使用 CSS 媒体查询 使用 CSS 媒体查询可以根据不同的屏幕大小,应用不同的样式。例如,我们可以针对不同的屏幕大小,设置不同的布局方式、字体大小、图片大小等。以下是一个简单的媒体查询示例: ```css @media (max-width: 768px) { /* 在屏幕宽度小于 768px 时应用以下样式 */ body { font-size: 16px; } } @media (min-width: 769px) and (max-width: 992px) { /* 在屏幕宽度在 769px 到 992px 之间时应用以下样式 */ body { font-size: 18px; } } @media (min-width: 993px) { /* 在屏幕宽度大于 993px 时应用以下样式 */ body { font-size: 20px; } } ``` 以上代码将根据屏幕宽度的不同,应用不同的字体大小。 3. 使用响应式图片 在响应式布局中,图片也需要根据屏幕大小的不同,动态调整尺寸。可以通过以下两种方式实现: - 使用 CSS 设置图片的最大宽度和最大高度,让图片根据父元素的大小进行缩放。 ```css img { max-width: 100%; height: auto; } ``` - 使用 `<picture>` 元素或 `<img>` 元素的 `srcset` 属性,根据不同的屏幕大小,加载不同尺寸的图片。 ```html <picture> <source media="(min-width: 768px)" srcset="large.jpg"> <source media="(max-width: 767px)" srcset="small.jpg"> <img src="fallback.jpg" alt="fallback image"> </picture> ``` 以上就是使用 viewport 实现响应式布局的具体方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

故里2130

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值