响应式布局

响应式布局

响应式布局

1、响应式设计理念是基于流动布局、弹性图片 、弹性表格、弹性视频和媒体查询等技术的组合。使用百分比布局创建就懂的弹性页面。同事使用媒体查询来控制元素的变动范围,两者组合就是构成响应式布局的核心。

优点:

1、面对不同分辨率设备时,灵活性较强。
2、能够快捷解决设备显示适应问题。’

缺点:

1、兼容各种设备,工作量大,效率低下。
2、代码代码累赘,会出现隐藏无用的元素,加载时间长。
3、响应式设计是一种折中性质的设计解决方案,因多方面因素而达不到最佳效果。
4、一定程度上改变了网站原有的步聚结构,会出现用户混淆。

响应式布局

视口(viewport)的概念:

1、标签设置浏览器视口宽度。

媒体查询

媒体查询可以获取的值如下:

1、设备的宽和高 2、渲染窗口的宽和高 3、设备的手持方向
4、画面比例 5、设备比例 6、对象颜色或颜色列表
7、设备的分辨率
实例:
方法一:
@media all and(max-width:1024px){
//电脑横屏的
}
@media all and(max-width:768px){
//电脑竖屏的
}
方法二:

弹性布局

1、弹性布局,也叫伸缩盒子或弹性盒布局。为display属性添加了新增:flex,并定义了一些新的属性。可以创建对浏览器窗口响应良好的流动页面。

2、一般有弹性布局的容器和弹性布局伸缩项目组成。
(1)、容器值采用弹性布局的DOM元素。
(2)、伸缩项目指的是容器中包含的子DOM元素。

三要素:

(1)、弹性基准(display:flex;)
(2)、弹性方向(flex-direction:row;)
(3)、是否换行(flex-wrap:wrap;)

属性:

1、弹性显示顺序:order:1;
2、弹性基准:flex-basis:0%;
3、伸缩比例:flex-sherink:1;
3、扩展比例:flex-grow:1;
如:flex:1 1 auto;
4、主轴对齐:
(1)、justify-context:flex-end
(2)、针对内容对齐:justify-content:space-around;
5、垂直排列:flex-direction:column;

多列布局

设置列数: column-count:3;
由浏览器自动调整列宽:column-fill:balance;
列与列之间的样式:column-rule:medium solid black;
列与列之间的距离:column-gap:10px;
当过长时隐藏:overflow:auto;

2.3图片边框

边框:border:solid 100px;
图片边框:border-image:url() 100 stretch;
注:stretch表拉伸;round表环绕;repeat表平铺

2.4渐变背景:

一、线性渐变:颜色沿着一条直线过度,从一种颜色到另一种颜色的平滑渐变。
Linear-gradient([[|to],]?[,]< color-stop >+)
二、径向渐变:指以一个点为中心向四周扩散的渐变。
Redial-gradient(设置渐变中心,渐变形状,渐变大小,起始颜色值,中心颜色值)

2.5图片背景美化

Background-clip和background-origin属性值如下:
Border-box:在边框盒子内部绘制背景颜色和背景图片
Padding-box:在内边距盒子内部绘制背景颜色和背景图片
Content-box:在内容盒子内部绘制背景颜色和背景图片
方式:
设置位置:
Background-origin:border-box或者Padding-box或者Padding-box;
剪切:
Background-clip:content-box或者Padding-box或者Content-box;

3.1过度

1、//返回后的动画
strong{
transition-delay:10ms;
transition-duration:250ms;//过度周期
}
//最终效果
strong:hover{
font-size:x-large;
border:solid 2px #000000;
padding:5px;
color:#ffffff;
background-color:#054808
trasition-delay:0.1s;//延迟0.1s执行
transition-duration:600ms//执行周期
transition-property:font-size,border,padding,background;//设置过渡属性
}
css源码:
.strong{
color: #000;
transition-delay: 10ms;
transition-duration: 600ms;
}
.strong:hover{
font-size: x-large;
border: solid 2px #000;
padding: 5px;
color: #ffffff;
background: #054808;
transition-delay: 0.1s;
transition-duration: 600ms;
transition-property: font-size,border, padding,color,background-color;
}
2、transition:all 5s ease 0.3s;
注:all表所有属性; 5s表示动画执行5秒; 效果为ease; 延迟0.3s
还有很多如:ease、ease-in、ease-out、ease-in-out
background:#FF3366;

3.2动画

定义:动画本质上是增强的过渡,css3动画基于关键帧,动画是分两部分定义的。
(1)、@key-frames规则创建一个动画并定义应用动画的属性。
(2)、animation及其相关属性调用关键帧以实现动画。
简写格式如下:
animation:关键帧组名 持续时间 动画速度 延迟时间 播放次数;
实例:
@keyframes text-anim{\动画组名
from{
color: #000;
}
50%{
color:#ff0000;
}
75%{
color: #00ff00;
}
to{
color:#ffffff;
font-size: x-large;
border-radius: solid 2px #000;
padding: 5px;
background-color:#054808;
}
}
.strong:hover{\用伪类启动动画
animation-delay: 100ms;
animation-duration: 600ms;
animation-iteration-count: infinite;\循环次数
animation-direction: alternate;\循环方向(alternate表示反向执行)
animation-timing-function: linear;//线性变化
animation-name: text-anim; //指明是那个动画组
}

3.3平移和缩放变换

定义:变换是使元素改变形状、尺寸和位置的一种效果,通过CSS3变换能够对元素进行移动、缩放、旋转或扭曲。
变换使用transform属性来实现。
平移是基于元素中心位置发生变化的。
使用方式:
translate(水平平移大小,垂直平移大小);
translateX(水平平移大小);
translateY(垂直平移大小);
缩放变换包含scale(x,y)、scaleX(n)和scaleY(n)3个方法。
使用方法:
scale(水平缩放倍数,垂直缩放倍数);(小于1表缩小大于1表放大)
scaleX(水平缩放倍数); 或者 scaleY(垂直缩放倍数);
也可以一起使用:
transform:scaleX(水平缩放倍数) translateX(水平平移大小);

3.4旋转和倾斜变换

定义:旋转变换使用transform属性rotate函数实现,CSS3的旋转变换是依靠角度变换的。用正值围绕元素中心时顺时针旋转,用负值则逆时针旋转。
使用transform-origin属性指定旋转变换的起点。默认状态以中心为起点。
可以使用tranlate方法将元素的;原点(0,0)移动到什么地方,就在什么地方旋转,所以先调用tranlate方法,再调用rotate方法。
在CSS3实现倾斜变换有以下实现方法:
(1)、skew(x-angle,y-angle)定义2d沿着x轴和y轴倾斜旋转。
(2)、skewX(angel)就是将元素以旋转基点为坐标原点,沿x轴方向拉伸一定角度。
(3)、skewY(angel)就是将元素以旋转基点为坐标原点,沿y轴方向拉伸一定角度。
设置元素中心点:transform-origin:top left;(top、left表位置可以用百分比表示)
设置旋转:transform:rotate(45deg);\设置角度不加deg表弧度
设置倾斜角度:transform:skew(25deg,25deg);或者 skewX(25deg);或者 transform:skewY(25deg);

4.1游戏商城

设计三原则:化繁为简(共同性)、化零为整(一致性)、化静为动(灵活性)
首页布局原则:先主体后细节。
头部:header
中心部分:section
底部:footer
2、css样式命名规则:
对于大型网站的Web页面来说,组织和管理如此大量的CSS样式代码是一个问题。二BEM是现代大型项目中CSS代码的组织方式。
BEM通过CSS语义化的命名约定和CSS层的分离,将有助于css的可扩展性,性能的提高和代码的组织管理。BEM来源于3各组成的英文首字母,分别是:块(Block)、元素(Element) 修饰符(Modifier)。
命名原则:
(1)、BEM实体名称全部是小写字母或数字。名称中的不同单词用单个连字符(-)分隔。
(2)、BEM元素名称和块名称之间通过两个下划线(_)分隔。
(3)、布尔修饰符和其所修饰的实体名称之间通过两个连字符(-)不使用名值对修饰符。

weixin_43999182 发布了5 篇原创文章 · 获赞 0 · 访问量 82 私信 关注

原文地址:https://blog.csdn.net/weixin_43999182/article/details/103667681

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


一:display:flex布局display:flex是一种布局方式。它即可以应用于容器中,也可以应用于行内元素。是W3C提出的一种新的方案,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持。Flex是FlexibleBox的缩写,意为"弹性布局",用来为盒状模型提供最大的灵
1. flex设置元素垂直居中对齐在之前的一篇文章中记载过如何垂直居中对齐,方法有很多,但是在学习了flex布局之后,垂直居中更加容易实现HTML代码:1<divclass="demo">2<divclass="inner">3<p>这是一个测试这是一个测试这是一个测试这是一个测试这是一个测试</p>4</div
移动端开发知识点pc端软件和移动端apppc端软件是什么,有哪些应用。常见的例子,比如360杀毒,photoShop,VisualStudioCode等等移动端app是什么,有哪些应用。常见的例子,比如手机微信,手机qq,手机浏览器,美颜相机等等PC端与移动端的区别第一:PC考虑的是浏览器的兼容性,移动端考
最近挺忙的,准备考试,还有其他的事,没时间研究东西,快周末了,难得学点东西,grid是之前看到的,很好奇,讲的二维的布局,看起来很方便,应该很适合移动端布局,所以今天抽时间学一学,这个当是笔记了。参考的是阮老师的博客。阮一峰:CSSGrid网格布局教程http://www.ruanyifeng.com/blog/2019/03/g
display:flex;把容器设置为弹性盒模型(设置为弹性盒模型之后,浮动,定位将不会有效果)给父元素设置的属性:(1)display:flex---把容器设置为弹性盒模型。(2)flex-direction---设置弹性盒模型主轴方向默认情况下主
我在网页上运行了一个Flex应用程序,我想使用Command←组合键在应用程序中触发某些操作.这在大多数浏览器上都很好,但在Safari上,浏览器拦截此键盘事件并导致浏览器“返回”事件.有没有办法,通过Flex或通过页面上的其他地方的JavaScript,我可以告诉Safari不要这样做?解决方法:简短的
flex布局,flex-item1<template>2<viewclass="container">3<viewclass="greentxt">4A5</view>6<viewclass="redtxt">7B8<
我应该设计一个大型多点触控屏幕的应用程序.从大到大,我的意思是新闻广播员(大约55英寸及以上).该应用程序是一个交互式地图.我的问题是:开发应用程序的技术.我的第一个想法是在AdobeFlex中制作,但是HTML5也是如此……必须有一些非常棒的Java库用于触摸交互,但是在Windows平台上
<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><metahttp-equiv="X-UA-Compatible&quo
【1】需求:  【2】解决方案:最近遇到布局上要求item两端对齐,且最后一行在列不满的情况下要求左对齐,使用flex的justify-content:space-between;实现时发现最后一行不能左对齐,而是两端对齐方式。 不是项目上想要的效果#网上查了一些资料,有两种方法可以实现效果:**1.
我有一个java套接字服务器,它在连接时将Animal对象发送到Flash客户端.对象发送方式如下:Amf3Outputamf3Output=newAmf3Output(SerializationContext.getSerializationContext());amf3Output.setOutputStream(userSocket.getOutputStream());amf3Output.writeObject(animal)
我正在开发一个Flex3.4应用程序,它通过最新版本的BlazeDS与JBoss-4.2.2服务器上运行的JavaEE后端进行交互.当我在Tomcat上从FlashBuilder4beta2运行Flex应用程序时,一切都很好,Flex应用程序能够进行所需的远程调用.但我的生产环境是在JBoss上,当我将应用程序移动到JBoss时(更
我有一个非常大的问题.我使用Flex3/Tomcat/BlazeDS/Spring编写了一个大型应用程序,在本地开发时运行良好,当我部署到公共开发环境时很好,但是当部署到我们的测试环境时经常失败.当远程处理请求花费大量时间(超过20秒)时,故障似乎最常发生.在我的开发服务器上,错误发生,但仅
弹性和布局display:flex在ie6,ie7不兼容状态,一般在pc用的比较少,在手机端所有的浏览器都是支持的控制子元素在父元素里面的位置关系display:flex是给父元素加的文档流是按照主轴排列,只要父元素加了flex,那么里面的子元素全部可以直接添加宽高主轴的方向
FLEX2.0源码分析(一)https://www.jianshu.com/p/8bc4c5f4b19fFLEX源码分析二(网络监测swizzle)https://www.jianshu.com/p/ffb95f2cbda6FLEX源码分析三(网络监测记录FLEXNetworkRecorder)https://www.jianshu.com/p/66267dc922c5FLEX源码分析四(Systemlog)https://www.jianshu.
1<!DOCTYPEhtml>2<htmllang="en">3<head>4<metacharset="UTF-8">5<title><itle>6<style>7*{8margin:0;9padding:0;10
<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><metahttp-equiv="X-UA-Compatible&qu
flex:将对象作为弹性伸缩盒显示inline-flex:将对象作为内联块级弹性伸缩盒显示两者都是使子元素们弹性布局,但是如果是flex,父元素的尺寸不由子元素尺寸动态调整,不设置时默认是100%,而inline-flex则会使父元素尺寸跟随子元素们的尺寸动态调整。
<html><head><metacharset="utf-8"><metaname="viewport"content="width=device-width"><title>test<itle><stylemedia="screen">.tab-head{list-style-type:no
有没有办法使用邮政编码找到径向距离?我的任务是搜索居住在指定距离内的所有用户.我知道用户的zipcodes.例如,距离当前位置25英里的用户.我有其他搜索类别,我正在使用mysql查询.我无法解决距离问题.我的后端是在PHP中Flex的前端和前端.对我来说最好的选择就是www.zip-codes.com