第三章总结

、盒子模型

       微信小程序的视图层由WXML和WXSS组成。其中,WXSS (WeiXin Style Sheets)是基
于CSS拓展的样式语言,用于描述 WXMI的组成样式,决定 WXMI的组件如何显示。WXSS 具有CSS 的大部分特性。

       在页面设计中,只有掌握了盒子模型以及盒子模型的各个属性和应用方法,才能轻松控制页面中的各个元素。

      盒子模型就是我们在页面设计中经常用到的一种思维模型。在CSS中,一个独立的盒子模型由内容(content)、内边距(padding)、边框(border)和外边距(margin) 4个部分组成。

盒子模型结构此外,对padding、border和margin可以进一步细化为上、下、左、右4个部分,在CSS中可以分别进行设置。
盒子模型元素
盒子模型元素 图中的元素的含义如下:

【1】:width 和 height:内容的宽度与高度

【2】:padding-top、padding-right、padding-bottom 和 padding-left :上内边距、右内边距、下内边距与左内边距

【3】:border-top、border-right、border-bottom 和 border-left:上边框、右边框、下边框与左边框

【4】: margin-top、margin-right、margin-bottom 和 margin-left:上外边距、右外边距、下外边距与左外边距

2、块元素和行元素
         元素按显示方式分为块级元素、行内元素与行内块元素,它们的显示方式由display属性控制。

1、块级元素

        块级元素默认占一行高度,一行内通常只有一个块级元素(浮动后除外),添加新的块
右级元素时,会自动换行,块级元素一般作为盒子出现。块级元素的特点如下:
       (1)一个块级元素占一行。

       (2)块级元素的默认高度由内容决定,除非自定义高度。

       (3)块级元素的默认宽度是父级元素的内容区宽度,除非自定义宽度。

 (4)块级元素的宽度、高度、外边距及内边距都可以自定义设置。

       (5)块级元素可以容纳块级元素和行内元素。

      <view/>组件默认为块级元素,使用<view/>组件演示盒子模型及块级元素的示例代码如下:

块级元素
<view style="border: 1px solid#f00;">块一</view>
 
<view style="border: 1px solid#0f0;margin: 15px; padding: 20px;">块二</view>
 
<view style="border: 1px solid#00f;width: 200px; height: 80px;">块三</view>
 
<view style="border: 1px solid#ccc;">
<view style="height: 60px;">
块四
</view>
</view>
 
<view style="border: 1px solid#f00;width: 100px;background-color: #ccc;">
父级元素高度随内容决定,内容为文本
</view>块级元素
<view style="border: 1px solid#f00;">块一</view>
 
<view style="border: 1px solid#0f0;margin: 15px; padding: 20px;">块二</view>
 
<view style="border: 1px solid#00f;width: 200px; height: 80px;">块三</view>
 
<view style="border: 1px solid#ccc;">
<view style="height: 60px;">
块四
</view>
</view>
 
<view style="border: 1px solid#f00;width: 100px;background-color: #ccc;">
父级元素高度随内容决定,内容为文本
</view>块级元素
<view style="border: 1px solid#f00;">块一</view>
 
<view style="border: 1px solid#0f0;margin: 15px; padding: 20px;">块二</view>
 
<view style="border: 1px solid#00f;width: 200px; height: 80px;">块三</view>
 
<view style="border: 1px solid#ccc;">
<view style="height: 60px;">
块四
</view>
</view>
 
<view style="border: 1px solid#f00;width: 100px;background-color: #ccc;">
父级元素高度随内容决定,内容为文本
</view>

行内元素


       行内元素,不必从新一行开始,通常会与前后的其他行内元素显示在同一行中,它们不占有独立的区域,仅靠自身内容支撑结构,一般不可以设置大小,常用于控制页面中文本的splay
样式。将一个元素的display属性设置为inline后,该元素即被设置为行内元素。

行内元素的特点如下:
       (1)行内元素不能被设置高度和宽度,其高度和宽度由内容决定。

       (2)行内元素内不能放置块级元素,只级容纳文本或其他行内元素。

       (3)同一块内,行内元素和其他行内元素显示在同一行。

       <texI/>组件默认为行内元素,使用<view/ >及<text/>组件演示盒子模型及行内元素的示例代码如下

行内元素
<view style="padding: 20px;">
<text style="border: 1px solid #f00;">文本一</text>
<text style="border: 1px solid #0f0;margin: 10px;padding: 5px;">文本二</text>
<view style="border: 1px solid #00f;display: inline;">块级元素设置行内元素</view>
3、行内块元素

       当元素的 display属性被设置为inline-block时,元素被设置为行内块元素。行内块元素可以被设置高度、宽度、内边距和外边距。示例代码如下:
 

行内块元素
<view>
元素显示方式的<view style="display:inline-block;border: 1px solid #f00;margin: 10px;padding: 10px;width: 200px;">块级元素、行内元素、行内块元素
</view>三种元素
</view>
3、浮动与定位
1、元素浮动

       元素浮动就是指设置了浮动属性的元素会脱离标准文档流的控制,移到其父元素中指定位置的过程。在CSS中,通过float属性来定义浮动,其基本格式如下

{float:none|left|right;}
其中:none——默认值,表示元素不浮动

           left——元素向左浮动

           right——元素向右浮动

实列代码如下:

<-何弃疗呀->
浮动
<view>box1、box2、box3未浮动</view>
<view style="border: solid 1px #f00;padding: 5px;">
  <view style="border: solid 1px #f00;">box1 </view>
  <view style="border: solid 1px #0f0;">box2</view>
  <view style="border: solid 1px #0f0;">box3 </view>
</view>
<view>box1左浮动</view>
<view style="border: solid 1px #f00;padding: 5px;">
  <view style="float: left; border: solid 1px #f00;">box1 </view>
  <view style="border: solid 1px #0f0;">box2</view>
  <view style="border: solid 1px #0f0;">box3 </view>
</view>
<view>box1、box2左浮动</view>
<view style="border: solid 1px #f00;padding: 5px;">
  <view style="float: left; border: solid 1px #f00;">box1 </view>
  <view style="float: left; border: solid 1px #0f0;">box2</view>
  <view style="border: solid 1px #0f0;">box3 </view>
</view>
<view>box1、box2、box3左浮动</view>
<view style="border: solid 1px #f00;padding: 5px;">
  <view style="float: left; border: solid 1px #f00;">box1 </view>
  <view style="float: left; border: solid 1px #0f0;">box2</view>
  <view style="float: left; border: solid 1px #0f0;">box3 </view>
</view>
<view>box3右浮动</view>
<view style="border: solid 1px #f00;padding: 5px;">
  <view style="border: solid 1px #f00;">box1 </view>
  <view style="border: solid 1px #0f0;">box2</view>
  <view style=" float: right; border: solid 1px #0f0;">box3 </view>
</view>

2、元素清除

        由于浮动元素不在占用原文档流的位置,因此它会对页面中其他元素的排列产生影响。在CSS中,clear属性用于清除浮动元素对其他元素的影响,其基本格式

{clear:left|right|both|none}
清除左边浮动的影响,也就是不允许左侧有浮动元素
           right——清除右边浮动的影响,也就是不允许右侧有浮动元素

           both——

           none——

实列代码如下

清除浮动
<view>box1、box2左浮动、box3清除左浮动</view>
<view style="border: solid 1px #f00;padding: 5px;">
  <view style="float: left; border: solid 1px #f00;">box1 </view>
  <view style="float: left; border: solid 1px #0f0;">box2</view>
  <view style="clear: left; border: solid 1px #0f0;">box3 </view>
</view>
另外,还可以在父元素外添加一个空元素,实现父元素包裹浮动元素。代码如下:

<view>box1、box2、box3:左浮动,在父元素后添加一个空元素</view>
<view style="border: solid 1px #f00;padding: 5px; "class="clearfloat">
  <view style="float: left; border: solid 1px #f00;">box1 </view>
  <view style="float: left; border: solid 1px #0f0;">box2</view>
  <view style="float: left; border: solid 1px #0f0;">box3 </view>
</view>
5 定位

5.1 相对定位

使用相对定位的盒子,会相对于它原来的位置,通过偏移指定的距离,到达新的位置
使用相对定

.box {
    position: relative;
    top: 10px;
    left: 20px; } 
位的盒子,仍在标准流中,它对父块好兄弟盒子没有任何影响

5.2 绝对定位

使用绝对定位的盒子以它"最近"的一个"已经定位"的"祖先元素"为基准进行偏移. 如果没有已经定位的"祖先元素", 那么会以浏览器窗口为基准进行定位
绝对定位的框从标准流中脱离,这意味着它们对其后的兄弟盒子的定位没有影响,其他的盒子就好像这个盒子不存在一样
 

.box {
    position: absolute;
    top: 10px;
    left: 20px } 
5.3 固定定位

以浏览器窗口为基准 窗口滚动时,依然保持位置不变

.box {
    position: absolute;
    top: 10px;
    left: 20px } 
5.4 空间位置

使用css属性 z-index设置元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。
z-index 仅能在定位元素上奏效
5.5 定位相关CSS属性总结

position static(默认值) /relative /position /fixed
top
left
right
bottom
z-index auto(默认值)/数字

6 浏览器兼容性
6.1 浏览器分类
主流浏览器(原生浏览器)
拥有独立内核的浏览器 被称为主流浏览器
chrome 内核 blink 早期的chrome使用apple的开源内核 webkit. 我们依然习惯上称呼chrome的内核为webkit
safari 内核 webkit
IE 内核 Trident
Firfox 内核 Gecko
Opera v12.17以前采用 Presto 内核。后来紧跟chrome的步伐,使用chrome的内核 成为了壳浏览器
壳浏览器
在某浏览器内核之上增加相应的辅助功能,并改变其名称与外观的浏览器

opera、360安全、360极速、UC、搜狗、猎豹、QQ浏览器、2345浏览器、淘宝浏览器 等

6.2 浏览器对HTML5和CSS3的兼容性情况

HTML5需要 IE9以及以上版本的IE浏览器支持
CSS3不同的模块对浏览器的兼容程度各不相同。 对于IE浏览器,肯定需要IE9以及以上的浏览器支持
chrome、firefox浏览器一般都会自动更新,所以兼容性特别棒!
手机浏览器,大多使用webkit内核,兼容性较好。关键是 手机上没有IE!
目前的国产浏览器,多采用双内核,使用chrome内核的时候兼容性较好

6.3 兼容技巧

设置IE使用最新的渲染引擎

<meta http-equiv="X-UA-Compatible" content="IE=Edge"> 
让双核浏览器默认使用webkit内核

<meta name="renderer" content="webkit"> 
让IE8识别HTML5新增标签

<!--[if lt IE 9]>
    <script src="/html5shiv/dist/html5shiv.js"></script>
<![endif]-->

chenwei0504
关注

0


2

0

3.第三章总结1
08-08
第三章总结晶体管高频小信号等效电路Y参数等效电路 混合π型等效电路分类单调谐谐振放大器双调谐谐振放大器图异以并联谐振回路作为负载矩形系数较大 —— 带宽衰减因子
半导体材料:半材第3章总结.doc
11-28
半导体材料:半材第3章总结.doc
计算机网络第三章总结_计网第三章_
10-03
计算机网络第三章内容总结,转发请标明出处
第3章总结1
08-03
USACO 第三章通关总结全面的总结2010ADVENTop2010/2/92USACO 第三章通关总结By ADVENTop三章总体上感觉并不太困难,但是有很
荣政第三章总结1
08-08
荣政第三章总结1
计算机网络第三章知识总结.docx
09-11
计算机网络第三章知识总结
《python数据分析与挖掘实战》第三章总结.docx
05-23
《python数据分析与挖掘实战》-张良均,第三章总结的读书笔记 记录我的学习之旅,每份文档倾心倾力,带我成我大牛,回头观望满脸笑意,望大家多多给予意见,有问题或错误,请联系 我将及时改正;借鉴文章标明出处,...
计算机组成原理-第3章总结.pdf
10-06
计算机组成原理-第3章总结.pdf
信号与系统第三章傅里叶变换总结信号三.docx
04-21
欢迎大家一起学习,不喜勿喷
计算机网络第三章知识点总结1
08-03
第三章:运输层掌握1. 计算机网络向用户提供的最重要的两大功能:连通和共享。2. UDP 和 TCP 通过检验和来实现差错检测。(掌握检验和的计算。)3. 流水
第4章总结1
08-03
USACO 第四章通关总结2USACO 第四章通关总结By ADVENTop四章相比较于前三章是一个不错的进阶,前三章重在基础,第四章则加入了更多精妙的算法思想
应用题及知识点总结 第三章栈
06-30
应用题及知识点总结 第三章栈应用题及知识点总结 第三章栈应用题及知识点总结 第三章栈应用题及知识点总结 第三章栈应用题及知识点总结 第三章栈应用题及知识点总结 第三章栈应用题及知识点总结 第三章栈应用题及...
JS总结第二章
02-21
JS总结第二章自己写的总结 请大家下载看看 谢谢
JS总结第三章
02-21
JS总结第三章自己写的 请大家下载 谢谢
人工智能课程第三章 Infromed Search 总结
05-31
人工智能课程第三章 Infromed Search 总结
计算机网络第三章知识点总结 1
08-03
第三章:运输层掌握1. 计算机网络向用户提供的最重要的两大功能:连通和共享。2. UDP 和 TCP 通过检验和来实现差错检测。(掌握检验和的计算。)3. 流水
PMP第六版前三章知识点总结
05-28
第六版PMP前三章重要知识点串讲,对项目的基本要素、项目的运行环境、项目经理的角色等知识点总结
用 Notepad++ 写 Java 程序
chengkai730的博客
 579
用 Notepad++ 写 Java 程序
【微信小程序】事件传参的两种方式
最新发布
云泽野の编程日记
 440
事件传参:在触发事件时,将一些数据作为参数传递给事件处理函数的过程,就是事件传参在微信小程序中,我们经常会在组件上添加一些自定义数据,然后在事件处理函数中获取这些自定义数据,从而完成业务逻辑的开发.小程序进行事件传参的时候,除了使用data-*属性传递参数外,还可以 使用 mark 标记传递参数mark 是一种自定义属性,可以在组件上添加,用于来识别具体触发事件的 target 节点。同时 mark 还可以用于承载一些自定义数据然后通过事件对象进行获取自定义数据,在组件上使用mark:自定义属性。
按照此结构 第一章 需求分析 第二章硬件选择分析 第三章软件设计 第四章测试分析 第五章总结 写一篇基于arduino的雨滴传感器课程设计
02-15
第三章 软件设计 在本章中,我们将对arduino雨滴传感器的软件进行设计。我们将考虑如何通过arduino编程语言来控制传感器,并对传感器的数据进行处理
————————————————

                            版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
                        
原文链接:https://blog.csdn.net/chenwei0504/article/details/139608692

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值