前端 什么是响应式设计

响应式设计是一种让网站在不同屏幕尺寸下呈现不同布局的方法。它通过媒体查询等技术实现,如设置视口标签、响应式字体和图片。响应式布局减少了工作量并节省了成本,但也存在兼容性、加载速度等问题。Bootstrap和一些知名网站已采用此技术。了解响应式设计的关键包括媒体查询、移动设备优先和大屏幕设备优先策略。
摘要由CSDN通过智能技术生成

1、什么是响应式设计

也叫响应式布局,响应式开发

实现不同屏幕分辨率的终端上浏览网页的不同展示方式。

响应式布局是根据设备屏幕宽度不同适当调整标签显示的布局,从而在每种设备屏幕宽度下呈现的界面是不同的

响应式布局

原理:

  • 一个网站适配所有终端,实现不同屏幕分辨率下的终端上网页的不同布局;

  • 使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而达到适配不同屏幕的目的

简单的说:

响应式布局是元素随着屏幕发生宽高大小变化 + 盒子布局发生变化

自适应:元素随着屏幕发生宽高大小变化

优缺点

优点:

  • 1、减少工作量,网站、设计、代码、内容都 只需要一份,多出来的工作量只是JS脚本、CSS样式做一些改变

  • 2、节省设计、开发、维护成本【不再特定的维护PC页面,移动页面】

  • 3、面对不同分辨率设备灵活性强,能够快捷解决多设备显示适应问题

缺点:

  • 1、兼容问题(IE8以下不支持)

  • 2、需要加载更多的样式和脚本文件

  • 3、代码累赘,会出现隐藏无用的元素,加载时间加长

  • 4、页面设计比较难于精确定位和控制

  • 5、影响用户体验(一定程度上改变了网站原有的布局结构,会出现用户混淆的情况,)

Bootstrap框架、苹果官网和星巴克官网使用的响应式布局

响应式网站演示:SegmentFault 思否

2、响应式需要的技术 :

1.设置视口标签

2.使用媒体查询

3.响应字体

4.响应图片

5.采用百分比

1、媒体查询

1、标签设置

meta标签的设置

1.虚拟窗口:创建虚拟窗口,自定义窗口的大小和缩放功能,能适应移动设备的屏幕大小

<meta name="viewport" content="width=device-width, initial-scale=1.0">

2.使用高版本的IE内核浏览器或者Chrome浏览器

<meta http-equiv="X-UA-Compatible" content="ie=edge,chrome=1">
​
http-equiv = "X-UA-Compatible":
​
这个是针对ie8以上浏览器的一个属性,ie8以下无法识别。就是说ie8以上浏览器遇到这个属性会执行content的描述,大小写不敏感。

2、使用媒体查询适配对应样式

可以根据设备显示器的特性,来设置不同的css的样式

2、媒体查询的引入方式和语法

1、媒体查询的语法

媒体查询的语法:
        
         @media mediaType and (media feather) {
            选择器 {
                属性名:属性值
            }
        } 
多个条件:
       @media mediaType and (media feather) and (media feather){
            选择器 {
                属性名:属性值
            }
        } 
​
        mediaType:设备类型
        media feather:媒体特性表表达式
​
​
 1.mediaType设备类型:
     all:所有的多媒体设备
     print:打印机或打印预览
     screen:电脑屏幕、平板电脑、智能手机等
     speech:屏幕阅读器等发声设备
​
2.media feather:媒体特性表达式
      width:浏览器的宽度
      height:浏览器的高度
      max-width:最大宽度
      min-width:最小宽度
      device-width:设备宽度
      device-height:设备高度
      max-device-width:最大设备宽度
      min-device-width:最小设备宽度
​
      orientation:设备的窗口朝向
          1.横屏   宽度比高度大   orientation:landscape;
          2.竖屏   高度比宽度大   orientation:portrait;
     
​
3.操作符
- and(与、和)
  not: not是用来排除掉某些特定的设备的,比如 @media not print(非打印设备)
  only: 用来定某种特别的媒体类型。
​
  /* 除了 speech 设备都可以用*/
    @media not speech {
      body {
        background-color: tomato;
      }
    }
​
    /* 只能在s
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值