移动端响应式

一、css3的@media媒体查询
1、定义和使用

       @media 可以针对不同的屏幕尺寸设置不同的样式,特别是如果你需要开发响应式的页面,@media 是非常有用的。当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面,这对调试来说是一个极大的便利。

       语法:

  @media mediaType and|not|only (media feature) {
    /*CSS-Code;*/
  }

       参数解释:

    mediaType(媒体类型):类型有很多,常用screen,用于电脑屏幕,平板电脑,智能手机等;

    media feature:常用如下两种值:

      max-width:定义输出设备中的页面最大可见区域宽度;

      min-width:定义输出设备中的页面最小可见区域宽度;

 

2、开始编写响应式页面

       a、准备工作一:设置Meta标签

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

              参数解释:

      width=device-width:宽度等于当前设备的宽度;

      initial-scale=1.0:初始的缩放比例(默认设置为1.0)

      user-scalable=no:用户是否可以手动缩放(设置为no,我们不希望用户放大缩小页面);

 

       b、准备工作二:加载兼容文件JS,因为IE8不支持HTML5和CSS3 的@media,所以需要加载两个JS文件,来保证我们的代码实现兼容效果

  <!--[if lt IE 9]>
     <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
  <![endif]-->

 

       c、准备工作三:设置IE渲染方式默认为最高(可选),现在有很多人的IE浏览器都升级到IE9以上了,所以这个时候就有又很多诡异的事情发生了,例如现在是IE9的浏览器,但是浏览器的文档模式却是IE8,为了防止这种情况,我们需要下面这段代码来让IE的文档渲染模式永远都是最新的

    <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">

    PS:这段代码后面加了一个chrome=1,如果用户的电脑里安装了chrome,就可以让电脑里面的IE不管是哪个版本的都可以使用Webkit引擎及V8引擎进行排版及运算,如果没有安装,就显示IE最新的渲染模式。

 

       d、代码示例:    

  <!DOCTYPE html>
  <html>
  <head>
    <meta charset="UTF-8">
       <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
       <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
       <title>响应式页面</title>
       <!--[if lt IE 9]>
      <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
         <script src="https://oss.maxcdn.com/libs/respond.js/1.3.0/respond.min.js"></script>
       <![endif]-->

    <style>
         @media screen and (min-width: 1200px){
        body{
          background-color: red; // 屏幕宽度大于等于1200px时生效
                 }
              }

            // 屏幕宽度大于等于800px,小于等于1200px时生效
      @media screen and (min-width: 800px) and (max-width: 1200px){
        body{
          background-color: green; 
          }
        }

      @media screen and (max-width: 800px){
        body{
          background-color: yellow;  // 屏幕宽度小于等于800px时生效
                 }
              }
    </style>
  </head>
  <body>

  </body>
  </html>
二、移动端单位介绍

       CSS中,W3C文档把尺寸单位划为为两类:相对长度单位和绝对长度单位。

       相对长度单位按照不同的参考元素,又可以分为字体相对单位和视窗相对单位:

              字体相对单位有:em、ex、ch、rem;

              视窗相对单位则包含:vw、vh、vmin、vmax几种;

       绝对单位则是固定尺寸,它们采用的是物理度量单位:cm、mm、in、px、pt以及pc。但在实际应用中,我们使用最广泛的则是px、百分比(%)、em以及rem来度量页面元素的尺寸。

              px:绝对(固定)单位;

              缺点:任何情况下都是固定值,会导致布局在不同尺寸下的设备错位;

 

              %:相对单位(会有影响发生变化)相对于父级(自身)大小进行定位;

              缺点:能确定范围的还是比较好计算的,对于不太好确定值得地方不好使用百分比,并且会导致变形,高度一般不好控制;

 

              em:相对单位 (会有影响发生变化) em=当前字体大小;

              缺点:会根据当前容器字体大小发生变化,假如每个容器字体大小不一致,那么计算会非常麻烦;

 

              rem:(r = root)相对单位,只依赖html字体大小;

              优点:响应式布局中应用;

 

       示例:动态的修改根元素font-size的js代码:

  /* 自执行函数
   * 获得页面宽度后动态修改html上的fontsize
   * 320为iphone5设计稿下的页面宽度,如下设置后的页面在iphone5等宽屏幕上
   * html的font-size会变为100px,即 1rem = 100px    1px=0.01rem
   * 所以设置元素尺寸的时候,如果测量设计稿 15px  则需设置尺寸为 (0.01*15)rem = 0.15rem   
   */

  !(function(doc, win) {
    var docEle = doc.documentElement;
    evt = "onorientationchange" in window ? "orientationchange" : "resize";
    fn = function() {
      var width = docEle.clientWidth;
      console.log(width)
      width && (docEle.style.fontSize = 100 * (width / 320) + "px");
    };
     
    win.addEventListener(evt, fn, false);
    doc.addEventListener("DOMContentLoaded", fn, false);
 
  }(document, window));

 

转载于:https://www.cnblogs.com/li-li/p/9762000.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3 提供了强大的响应式系统,这对于移动端的布局非常重要。在移动端开发中,响应式布局确保了页面在不同屏幕尺寸和设备上都能自适应地调整布局。Vue 3 的响应式主要依赖于以下核心机制: 1. **Vue实例的响应式属性**:Vue实例的data属性会自动转换为响应式的,这意味着当你修改这些属性时,视图会自动更新。这是通过劫持JavaScript的数据变更通知机制(Object.defineProperty)实现的。 2. **计算属性**:你可以定义计算属性,它们基于其他响应式的属性计算得出,也具备响应性。这使得复杂的计算变得简洁,不需要手动维护状态。 3. **Watch API**:虽然不是直接用于布局,但watch方法允许你在数据变化时执行回调,这对于动态调整样式或执行布局相关的逻辑非常有用。 4. **响应式指令**:Vue提供了一些响应式指令如v-bind, v-model等,用于绑定元素的属性,这些在移动端布局中也有广泛应用,比如v-bind:style可以动态设置元素的样式。 5. **Vue Router** 和 **Vuex** 的配合:当用户导航或组件状态改变时,响应式系统能保证视图的更新和路由的重渲染,这对于动态路由和复杂数据流的管理至关重要。 6. **Vue CLI** 提供的预构建工具和脚手架:可以帮助开发者快速创建适合移动端响应式布局,并支持各种屏幕尺寸的适配策略,如媒体查询和百分比布局。 对于移动端响应式布局的具体实现,你可能需要用到以下技术: - **CSS Flexbox** 或 **CSS Grid**:Vue3不直接处理布局,但你可以使用这两种现代CSS布局模式来创建灵活的网格和响应式容器。 - **CSS变量和主题**:使用CSS变量可以轻松地切换不同主题或屏幕尺寸的样式。 - **响应式设计库**:如Vuetify、Element UI等提供了预设的响应式组件和解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值