微信小程序 - 2.布局组件属性

一、wxss

官方文档 : https://developers.weixin.qq.com/miniprogram/dev/framework/view/wxss.html

1.尺寸单位

小程序规定了全新的尺寸的单位 "rpx" , 其原理是五十设备原先的尺寸 , 统一规定屏幕宽度为750rpx , 换算:

设备 rpx换算px(屏幕宽度为750)
iPhone 5 1rpx = 0.42px
iPhone 6 1rpx = 0.5px
iPhone 6 Plus 1rpx = 0.522px
  1. 小程序中 不需要主动引入样式文件
  2. 需要吧页面中某些元素的单位由 px 改为 rpx
    1. 设计稿 750px ; 750 px = 750 rpx ; 1 px = 1 rpx
    2. 把屏幕宽度改为 375px ; 375 px = 750rpx ; 0.5 ox = 1 rpx
    3. 存在一个设计稿 宽度未知 page
      (1) 设计稿 page 存一个元素 宽度100px
      (2) 拿以上需求取实现不同宽度样式的页面适配
      page px = 750 rpx ; 1 px = 750 rpx /page ; 100 px = 750 rpx * 100 / page
    4. 利用calc属性 (css和wxss都支持的一个属性)
      (1) 750和rpx中间不要留空格
      (2) 运算符的两边也不要留空格
 view{
     /* width: 200rpx; */
      height: 200rpx;
      font-size: 40px;
      background-color: turquoise;
      /* 以下代码写法是错误的 */
      /* width: 750rpx*100/375; */
      width: calc(750rpx*100/375);
  }
2.常用属性
background-color 背景色
color 前景色
font-size 字体大小
border 边框
width 宽度
height 高度

background-color

3.书写位置
  1. 内联样式 - style
<view style="color:red,background-color:yellow">测试</view>
  1. 业内样式 - class
    (1). 页面的wxss文件内的样式
    (2).会自动作用在同页面的wxml页面结构 ( 对其他页面无效 )
<view class="container"></view>

.wxss文件中定义container(前边必须要有. )

 .container{
    height: 100vh; /*高100视窗,这里写100%无效*/
    display: flex; /*flex布局方法 */
    flex-direction: column;/*垂直布局*/
    align-items: center;/*水平方向居中*/
    justify-content: space-around;/*垂直方向分散布局*/
}
  1. 全局样式 - app.wxss
    样式会作用所有页面结构
    app.wxss文件中定义一个样式
.testWxss{
  color: red;
  font-size: 50rpx;
}

引用wxml文件中直接使用

 <text class="testWxss">测试全局wxss样式</text>
直接显示效果
4.优先局
内联 > 页面 > 全局

tip : !important 可以提升优先局
wxml文件中定义两个view,都引用全局app.wxss中的样式,同时自己也加了样式

<view class="testWxss" style="color: blue;font-size: 30rpx;">测试全局wxss样式</view>
<view class="testWxssImp" style="color: blue;font-size: 30rpx;">测试全局wxss样式,app.wxss中增加了优先级</view>

app.wxss文件定义样式,其中一种使用!important增加优先级

.testWxss {
  color: red;
  font-size: 50rpx;
}
/* 使用!important增加了优先级 */
.testWxssImp {
  color: red !important;
  font-size: 50rpx !important;
}
加了!important样式的使用了全局的样式,而不是内联的样式

二、flex布局

1.基本概念
  1. 容器和项目
<view class="a">
    <view class="b">
         <view class="c"></view>
    </view>
</view>

对a,b而言 : a 容器 b 项目

对b,c而言 : b 容器 c 项目

  1. 坐标轴


    坐标轴
2.容器属性
1. flex-direction 决定元素的排列方向(用于设置主轴方向,通过设置坐标轴可以规定项目的排列方向)**
.container{
      display:flex;
      flex-direction:row(默认)  row-reverse | column | column-reverse
}

row : 默认值 , 主轴在水平方向上从左到右 , 项目按照主轴方向从左到右排列

row-reverse : 主轴是row的反方向 , 项目按照主轴方向从右到左排列

column : 主轴在垂直方向上从上而下 , 项目按照主轴方向从上往下排列

column-reverse : 主轴是column的反方向 , 项目按照主轴方向从下往上排列

2. justify-content 元素在主轴的对齐方向(用于设置项目在主轴方向上的对齐方式 , 以及分配项目之间及其周围多余的空间)**
    .container{

      display:flex;

      justifu-content:flex-start(默认值) flex-end | center | space-around | space-between

    }

flex-start : 默认值 , 标识项目对齐主轴起点 , 项目间不留空隙

center : 项目在主轴上居中排列 , 项目间不留空隙,主轴上第一个项目离主轴起点的距离等于最后一个项目离主轴重点的距离

flex-end : 项目对齐主轴重点 , 项目间不留空隙

space-between : 项目间距相等,第一个和最后一个项目分别离起点/终点的距离为0

space-around : 与space-between相似 , 不同之处为第一个项目里主轴起点和最后一个项目离主轴终点的距离为中间项目间距的一半

3. align-items 元素在交叉轴的对齐方向(用于设置项目在行中的对齐方式)**
.container{
     display:flex;
     align-items:stretch(默认值) | flxe-start | center | flex-end
}

stretch : 默认值 , 未设置项目尺寸时将项目拉伸至填满交叉轴

flex-start : 项目顶部与交叉轴起点对齐

center : 项目在交叉轴居中对齐

flex-end : 项目底部与交叉轴终点对齐

4. align-content 用于多行排列时设置项目在交叉轴方向的对齐方式 , 以及分配项目之间及其周围多余的空间**
.container{
    display:flex;
    align-content:stretch(默认值) | flex-start | center | flex-end | space-around | space-between
}

stretch : 默认值 , 未设置项目尺寸时将各行中的项目拉伸至填满交叉轴 , 当设置了项目尺寸时项目尺寸不变 , 项目行拉伸至填满交叉轴

flex-start : 首行在交叉轴起点开始排列 , 行间不留间距

center : 行在交叉轴中点开始排列 , 行间不留间距 , 首行离交叉轴起点和行尾离交叉轴终点的距离相等

flex-end : 尾行在交叉轴终点开始排列 , 行间不留间距

space-around : 行与行间距相等 , 首行离交叉轴起点和尾行离交叉轴终点的距离为行与行间距的一半

space-between : 行间间距、首行离交叉轴起点和尾行离交叉轴终点距离相等

5. flex-wrap 决定元素如何换行(用于规定是否允许项目换行 , 以及多行排列时换行的方向)**
.container{
    display:flex;
    flex-wrap:nowrap(默认值) | wrap | wrap-reverse
}

nowrap : 默认值 , 标识不换行 , 如果单行内容过多 , 项目宽度可能会被压缩

wrap : 当容器单行容不下所有项目时允许换行排列

wrap-reverse : 当容器单行容不下所有项目时允许换行排列 , 换行方向为wrap的反方向

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容