使用 HTML5 和 CSS3 制作登录页面完整步骤

小编辑 发布于 2011/09/22 09:37
阅读 37K+
收藏 45

本文详细介绍使用 HTML5 和 CSS3 制作一个登录页面的完整过程。

View demo

login.html

<form id="login">
    <h1>Log In</h1>
    <fieldset id="inputs">
        <input id="username" type="text" placeholder="Username" autofocus required>
        <input id="password" type="password" placeholder="Password" required>
    </fieldset>
    <fieldset id="actions">
        <input type="submit" id="submit" value="Log in">
        <a href="">Forgot your password?</a><a href="">Register</a>
    </fieldset>
</form>

所用到的 HTML5 的特性:

  • placeholder – 输入框的简短提示,当该输入框获得输入焦点时,该提示信息自动消失
  • required – 指定该输入元素是否必须提供
  • autofocus – 指定输入框是否在页面加载完毕自动获取输入焦点
  • type=”password” – 指定密码输入(非HTML5专有)

CSS

在这里我们用到了 CSS3 的一些专有属性,包括:

Box-shadow 可以帮我们制作效果很好的边框阴影

#login
{
    box-shadow:
          0 0 2px rgba(0, 0, 0, 0.2),
          0 1px 1px rgba(0, 0, 0, .2),
          0 3px 0 #fff,
          0 4px 0 rgba(0, 0, 0, .2),
          0 6px 0 #fff,
          0 7px 0 rgba(0, 0, 0, .2);
}

Stitch effect (缝效果)

#login
{
    position: absolute;
    z-index: 0;
}

#login:before
{
    content: '';
    position: absolute;
    z-index: -1;
    border: 1px dashed #ccc;
    top: 5px;
    bottom: 5px;
    left: 5px;
    right: 5px;
    -moz-box-shadow: 0 0 0 1px #fff;
    -webkit-box-shadow: 0 0 0 1px #fff;
    box-shadow: 0 0 0 1px #fff;
}

Subtle gradient lines (微妙的渐变线)

h1
{
    text-shadow: 0 1px 0 rgba(255, 255, 255, .7), 0px 2px 0 rgba(0, 0, 0, .5);
    text-transform: uppercase;
    text-align: center;
    color: #666;
    margin: 0 0 30px 0;
    letter-spacing: 4px;
    font: normal 26px/1 Verdana, Helvetica;
    position: relative;
}

h1:after, h1:before
{
    background-color: #777;
    content: "";
    height: 1px;
    position: absolute;
    top: 15px;
    width: 120px;
}

h1:after
{
    background-image: -webkit-gradient(linear, left top, right top, from(#777), to(#fff));
    background-image: -webkit-linear-gradient(left, #777, #fff);
    background-image: -moz-linear-gradient(left, #777, #fff);
    background-image: -ms-linear-gradient(left, #777, #fff);
    background-image: -o-linear-gradient(left, #777, #fff);
    background-image: linear-gradient(left, #777, #fff);
    right: 0;
}

h1:before
{
    background-image: -webkit-gradient(linear, right top, left top, from(#777), to(#fff));
    background-image: -webkit-linear-gradient(right, #777, #fff);
    background-image: -moz-linear-gradient(right, #777, #fff);
    background-image: -ms-linear-gradient(right, #777, #fff);
    background-image: -o-linear-gradient(right, #777, #fff);
    background-image: linear-gradient(right, #777, #fff);
    left: 0;
}

最终结果

View demo

结论

在一些老的浏览器上也表现不错,下图是在IE8下的效果:


加载中
1
1
hchen1982
hchen1982
这个确实漂亮
0
游客
游客
给力,可是学不会。
0
w
weimeishuxi
这个确实很漂亮!!
0
笨蛋EGG
笨蛋EGG
我准备用这些做一套东西····漂亮的说···
0
W
WangJianfei
就算是翻译的也要写上出处吧……
G.
G.
在"结论"的上一行
0
张攀
张攀
不能兼容所有浏览器呀
0
hantsy
hantsy
THML5 和 CSS3 各浏览器支持程序不一样,只有尽可能的使用最新的浏览器,IE9,Firefox 4以后等。
G.
G.
HTML5 !
0
duty
duty
ie8 是较老的浏览器。。我的ie6 情何以堪 呵呵。
G.
G.
如果工作需要用到IE6, 那还好理解一点, 如果不是的话... 好吧,我不说了.
0
贺师俊
输入框没有label作为提示是这个表单实现的最大缺点。placeholder并不是用来取代label的。在IE8上就可以看出,缺少placeholder也没有label的表单,是不够友好的。
G.
G.
有图标足已, 要 label 何用!
返回顶部
顶部