技术标签: 盒子里面图片的位置怎么设置 div搜索框与按钮不在一行 css使两个盒子并列
一个盒子我们会分成下面几个部分:
1.通过width和height实现一个100*100px的盒子
2.为盒子设置边框
为元素设置边框必须指定三个样式
.box{
/*
使用width来设置盒子内容区的宽度
使用height来设置内容区的高度
* */
width: 100px;
height: 100px;
/*设置背景颜色*/
background-color: #bfa;
/*为元素设置边框必须指定三个样式
border-width:边框宽度
border-color:边框颜色
border-style:边框样式
* */
border-width:10px;
border-color:red;
border-style:solid;
}
*width和height只是设置盒子内容区的大小,盒子可见框的大小由内容区,内边距和边框共同决定
3.使用border-width可以分别指定四个边框的宽度(之间用空格隔开)
如果在border-width指定四个值,则四个值会按照顺时针方向赋值给上、右、下、左边框
如果指定三个值,则分别设置给上、左右、下
如果指定两个值,则分别设置给上下、左右
如果指定一个值,则四边全为该值
*border-color和border-style也有这样的使用方法
4.除了border-width,css中还提供了四个border-xxx-width
xxx的值可能是top right bottom left
专门用来设置指定边的宽度
width也可以是color和style修改定边的颜色和样式
以下是魔改版:
*大部分浏览器中,边框的宽度和颜色都有默认值,而边框的样式的默认值都是none
所以样式一定要设置!
5.边框的简写属性
border
border-top border-right border-bottom border-left
可以单独设置四个边的样式,规则和border一样,只不过它只对一个边生效
小技巧:如果只想设置其中的三个边,可以把其中一个边设置为none
内边距(padding),指的是盒子的内容区和盒子边框之间的距离
一共有四个方向的内边距,可以通过:
padding-top
padding-right
padding-bottom
padding-left
来设置四个方向的内边距
内边距会影响盒子可见框的大小,元素的背景会延伸到内边距,像下面这样
在box盒子里面装一个box1盒子,方便对比
*盒子的大小由内容区,内边距和边框共同决定
外边距指的是当前盒子与其他盒子之间的距离
它不会影响可见框的大小,而是会影响盒子的位置
盒子有四个方向的外边距:
margin-top
margin-right
margin-bottom
margin-left
由于页面中的元素都是靠左靠上摆放的
所以当我们设置上和左外边距时,会导致盒子自身的位置发生改变
而如果是设置右和下外边距会改变其他盒子的位置
从上图可以看出设置右和下是没有效果的
再加一个盒子查看就能明显看到下面的盒子被挤下去了
外边距也可以是一个负值
如果外边距是负值,则元素会向反方向移动
margin还可以设置为auto,auto一般只设置给水平方向的margin
如果只指定左外边距或右外边距的margin为auto则会将外边距设置为最大值
垂直方向外边距如果设置为auto,则外边距默认就是0
如果将left和right同时设置为auto,则会将两侧的外边距设置为相同的值,
就可以使元素自动在父元素中居中
所以可以将左右外边距设置为auto,以使子元素在父元素中水平居中
外边距的简写属性margin,可以同时设置四方向的外边距,规则和padding一样
在网页中相邻的垂直方向的外边距会发生外边距的重叠
以下红色框是我特地框出来对比的,不属于css的内容
浏览器为了在页面没有样式时,也可以有一个比较好的显示效果,
所以很多的元素都设置了一些默认的margin和padding,
这些默认样式,正常情况下我们是不需要使用的。
所以我们往往在编写样式之前将需要的浏览器中默认的margin和padding统统去掉
1.内联元素不能设置width和height
2.可以设置水平方向的内边距,可以设置垂直方向的外边距,但不会影响页面的布局
3.内联元素可以设置边框,但是垂直的边框不会影响到页面的布局
4.内联元素支持水平方向的外边距,不支持垂直外边距
5.内联元素外边距不会重叠,而是求和
将一个内联元素变成块元素
通过display样式可以修改元素的类型
可选值:
inline:可以将一个元素作为内联元素显示
block:可以将一个元素设置块元素选择
inline-block:将一个元素转换为行内块元素
* 可以将一个元素既有行内元素的特点又有块元素的特点
* 既可以设置宽高,又不会独占一行,类似imgs
none:不显示元素,并且元素不会在页面中继续占有位置
block和inline-block的区别:
visibility
可以用来设置元素的隐藏和显示的状态
可选值:
* visible 默认值,元素默认会在页面显示
* hidden 元素会隐藏不显示
*使用visibility:hidden;隐藏的元素虽然不会在页面中显示,但是它的位置会依然保持
对比一下display:none
子元素默认是存在于父元素的内容区中,理论上讲子元素的最大可以等于父元素内容区大小
如果子元素的大小超过了父元素的内容区,则超过的大小会在父元素以外的位置显示
超出父元素的内容,我们称为溢出的内容
父元素默认是溢出内容,在父元素外边显示
通过overflow可以设置父元素如何溢出内容
可选值:
* visible,默认值,不会对溢出内容做处理,元素会在父元素以外的位置显示
* hidden,溢出的内容,会被修剪,不会显示
* scroll,会为父元素添加滚动条,通过拖动滚动条来查看完整内容,该属性不论内容是否溢 出,都会添加水平和垂直的双方向滚动条
* auto,会根据需求自动添加滚动条,需要垂直就垂直,要水平就水平,都不需要就不加
文档流处在网页的最底层,它表示的是一个页面的位置
我们所创建的元素默认都处在文档流中
元素在文档流中的特点:
块元素
1.块元素在文档流中独占一行,块元素会自上而下排列
2.块元素在文档流中默认宽度是父元素的100%
3.块元素在文档流中的高度默认被内容撑开
*当元素的宽度的值为auto时,此时指定内边距不会影响可见框的大小
而是会自动修改宽度,以适应内边距
内联元素
1.内联元素在文档流中只占自身的大小,会默认从左到右排列
如果一行中不足以容纳所有的内联元素,则换到下一行,继续自左向右
2.在文档流中,内联元素的宽度和高度默认都被内容撑开
块元素在文档流中默认垂直排列,所以这三个div自上至下依次排开,如果希望块元素在页面中水平排列,可以使块元素脱离文档流
使用float来使元素浮动,从而脱离文档流
可选值:
none,默认值,元素默认在文档流中排列
left,元素会自动脱离文档流,向页面的左侧浮动
right,元素会立即脱离文档流,向页面的右侧移动
当为一个元素浮动以后(float属性是一个非none的值)
元素会立即脱离文档流,元素脱离文档流以后,它下边的元素会立即向上移动
元素浮动以后,会尽量向页面的左上或者右上漂浮
直到遇到父元素的边框或者其他浮动元素
如果浮动元素上边没有一个浮动的块元素,则浮动元素不会超过块元素
浮动元素不会超过它上边的兄弟元素,最多一边齐
浮动的元素不会盖住文字,文字会自动环绕在浮动元素周围,可以通过浮动来设置文字环绕图片效果
在文档流中,子元素的宽度默认占父元素的全部
当元素设置浮动以后,会完全脱离文档流
块元素脱离文档流以后高度和宽度都被内容撑开
内联元素脱离文档流以后会变成块元素
文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr
文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc
文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8
文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束
文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求
文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname
文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立
文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码
文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词
文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限
文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定
文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland