ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

使用flex进行网易云音乐界面构建和布局解析(1)

2020-04-25 20:08:11  阅读:338  来源: 互联网

标签:flex 网易 界面 height html background rem position


使用flex进行网易云音乐界面构建和布局解析

1.为什么要用flex进行webapp布局

第一,float布局 需要清除浮动,很麻烦。

第二,绝对定位需要考虑位置和空间占位

第三,元素垂直水平居中问题。

2.网易云音乐首页分析

图片描述

3.啥也别说,直接上代码

先来一个html,

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>001</title>
</head>
<body>
   <div id="app">
       <div id="header"></div>
       <div id="navbar"></div>
       <div class="routerview">
           <div id="banner"></div>
           <div id="recommend-items"></div> 
           <div class="reco-list"></div>
       </div>
       <div id="footer"></div>
   </div> 
</body>
</html>

别的不说咱们先用色块把各部分堆出来,这个跟flex没半毛钱关系,只是用了rem.

html{
    font-size: 100px;
}
#header{
    background-color: #d32f2f;
    min-height: 0.48rem;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;

}
#navbar {
    position: fixed;
    top: 0.48rem;
    left: 0;
    right: 0;
    z-index: 1000;
    background: #ccc;
    min-height: 0.3rem;

}

#footer {
    height: 0.49rem;
    background: #2f2d2e;
    width: 100%;
    position: fixed;
    bottom: 0;
    left: 0;
    color: rgba(255, 255, 255, .87);
    font-size: 0.12rem;
}

.routerview {
    padding-bottom: 0.49rem;
}
.routerview {
    position: absolute;
    left: 0;
    top: 0.81rem;
    width: 100%;
    height: 2000px;
    background: #eeeeee;
}

接着往下就是重点了,我们来看看头部细节细节,左右图标,

       <div id="header">
        <div class="logo"></div>
        <div class="logo"></div>
       </div>

css部分,

#header{
    align-items: center;
    justify-content: space-between;
}

那中间部分三个等距怎么办?

html,

<div id="header">
    <div class="logo"></div>
    <div class="title">
    <div class="logo"></div>
    <div class="logo"></div>
    <div class="logo"></div>
    </div>
    <div class="logo"></div>
</div>

上css,

.title {
    display: flex;
    justify-content: center;
}

结果如下,

图片描述

最复杂的部分已经结束了,剩下的就很OK了。

最后给大家三个小尝试吧。

1.剩下的部分切出来。

2.解决动态的多屏幕适配问题(提示:js+rem动态计算)

//参考代码:
function getRem(pwidth,prem){
    var html = document.getElementsByTagName("html")[0];
    var oWidth = 2*document.body.clientWidth || document.documentElement.clientWidth;
    html.style.fontSize = oWidth/pwidth*prem + "px";
}

3.flex兼容性(提示:postcss)

本文转载于:猿2048→https://www.mk2048.com/blog/blog.php?id=hbachhbbckj

标签:flex,网易,界面,height,html,background,rem,position
来源: https://www.cnblogs.com/baimeishaoxia/p/12774953.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有