FE入门 — html、css基础

标签

常用标签

通过看http://www.w3school.com.cn/tags/index.asp,熟悉以下html标签:

<p></p>
<div></div>
<input>
<span></span>
<a></a>
<i></i>
<ul></ul>
<ol></ol>
<li></li>
<select></select><option></option>
<hr/>
<br/>

CSS基础

什么是CSS

CSS(Cascading Style Sheets)层叠式样式表,用于定义如何显示HTML元素。

CSS语法

CSS规则由两个部分构成:选择器,一条及多条声明。

选择器{属性:样式属性} 

selector{
property:value;
property2:value;
property3:value;
……
}

例如,我们要设置html中input的字体颜色及字体大小,就这样写:

input{
color:red;
font-size:14px;
}

选择器

选择器种类很多,常见的如下:

//元素选择器
input{
color:red;
}

//id选择器
#div1{
width:50px;
}

//类选择器
.active{
	color:red;
}

//属性选择器
[title]
{
color:red;
}

除此之外还有后代、兄弟、伪类选择器等等,具体知识点,请见CSS相关课程。

行内元素与块级元素

html元素分两类:行内元素、块级元素。他们有如下区别:

  1. 行内元素与块级元素直观上的区别:行内元素会在一条直线上排列,都是同一行的,水平方向排列;块级元素各占据一行,垂直方向排列。块级元素从新行开始结束接着一个断行。
  2. 块级元素可以包含行内元素和块级元素,行内元素不能包含块级元素。
  3. 行内元素与块级元素属性的不同,主要是盒模型属性上:行内元素设置width无效,height无效(可以设置line-height),margin上下无效,padding上下无效。

常见块级元素:

<div> - 常用块级容易,也是css layout的主要标签
<form> - 交互表单
<h1>-<h6> - 标题
<hr> - 水平分隔线
<p> - 段落 
<table> - 表格
<ul> - 非排序列表
<ol> - 排序表单

常见行内元素:

<a> - 链接
<br> - 换行
<em> - 强调
<img> - 图片
<input> - 输入框
<label> - 表格标签 
<select> - 项目选择
<small> - 小字体文本 
<span> - 常用内联容器,定义文本内区块
<strong> - 粗体强调 
<textarea> - 多行文本输入框 
<var> - 定义变量

块级元素和行内元素相互是可以转换的,只需要设置该元素的display属性:

display:block;//转换为块级
display:inline;//转换为行内

display:inline-block;//具有行内元素特性,又能像块级一样调整宽高

盒模型

14714028501135.jpg

标准 w3c 盒子模型的范围包括 margin(外边距)、border(边框)、padding(内边距)、content(内容)。
我们的html中的每个元素都可以看做一个盒子,都有上述四个属性。

绝对定位与相对定位

绝对定位

绝对定位(position: absolute):绝对定位是相对于元素最近的已定位的祖先元素(即是设置了绝对定位或者相对定位的祖先元素)。如果元素没有已定位的祖先元素,那么它的位置则是相对于最初的包含(body)。

绝对定位与文档流无关,所以它们可以覆盖页面上其他的元素,可以通过z-index属性来控制这些层的对方顺序。

#box_relative {
  position: absolute;
  left: 30px;
  top: 20px;
}

14714036960296.jpg

####相对定位

相对定位(position: relative):相对定位是相对于元素在文档中的初始位置;

注意,在使用相对定位时,无论是否进行移动,元素仍然占据原来的空间。因此,移动元素会导致它覆盖其它框。

#box_relative {
  position: relative;
  left: 30px;
  top: 20px;
}

14714037240005.jpg

注意:position:absolute,float会隐式地改变display的类型(display:none除外)。即是当元素设置position:absolute、float:left、float:right中任意一个时,都会让元素以display:inline-block的方式显示(特点是:可以设置长宽,默认宽度不占满父元素)。这时,即使故意设置display:inline;display:block都是无效的。

但是float在IE6下的双边距bug就是用display:inline; 来解决的。
position:relative不会隐式改变display的类型。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供一些 HTMLCSS 代码来创建漂亮的登录界面。以下是一个简单的示例: HTML 代码: ``` <!DOCTYPE html> <html> <head> <title>Login Page</title> <link rel="stylesheet" href="style.css"> </head> <body> <div class="login-box"> <h2>Login Here</h2> <form> <div class="user-box"> <input type="text" name="" required=""> <label>Username</label> </div> <div class="user-box"> <input type="password" name="" required=""> <label>Password</label> </div> <a href="#"> <span></span> <span></span> <span></span> <span></span> Submit </a> </form> </div> </body> </html> ``` CSS 代码: ``` body { margin: 0; padding: 0; font-family: sans-serif; background: linear-gradient(to right, #00C9FF, #92FE9D); } .login-box { width: 320px; height: 420px; background: #000; color: #fff; top: 50%; left: 50%; position: absolute; transform: translate(-50%, -50%); box-sizing: border-box; padding: 70px 30px; } h2 { margin: 0; padding: 0 0 20px; text-align: center; font-size: 22px; } .user-box { position: relative; } .user-box input { width: 100%; padding: 10px 0; font-size: 16px; color: #fff; margin-bottom: 30px; border: none; border-bottom: 1px solid #fff; outline: none; background: transparent; } .user-box label { position: absolute; top: 0; left: 0; padding: 10px 0; font-size: 16px; color: #fff; pointer-events: none; transition: 0.5s; } .user-box input:focus ~ label, .user-box input:valid ~ label { top: -20px; left: 0; color: #00bcd4; font-size: 12px; } a { text-decoration: none; display: inline-block; background: #00bcd4; color: #fff; padding: 10px 20px; margin-top: 40px; border-radius: 30px; transition: 0.5s; } a:hover { background: #fff; color: #00bcd4; } ``` 该代码将创建一个黑色背景的登录框,其中包括一个标题、“用户名”和“密码”输入框以及一个提交按钮。您可以根据需要进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值