zoukankan      html  css  js  c++  java
  • 前端基础之HTML

    写在前面



        理想三旬



    前言

    HTTP协议:
    	短连接:因为服务器的链接数是有限的。
    		如果一直维持一个长链接,那么资源会很快就被耗尽;
    		并且大部分情况下长链接都处在没有使用的情况:
    		比如你浏览博客园一个博文,只是在看文章,这种情况下链接就被浪费了。
    
    	无状态:即服务器端不保存客户端的任何状态。
    
    
    参考:http://www.cnblogs.com/li0803/archive/2008/11/03/1324746.html
    HTTP协议详解之请求篇
    
        http请求由三部分组成,分别是:请求行、消息报头、请求正文
    
    请求行以一个方法符号开头,以空格分开,后面跟着请求的URI和协议的版本,格式如下:
    Method Request-URI HTTP-Version CRLF
    	Method表示请求方法;
    	Request-URI是一个统一资源标识符;
    	HTTP-Version表示请求的HTTP协议版本;
    	CRLF表示回车和换行(除了作为结尾的CRLF外,不允许出现单独的CR或LF字符)。
    
    请求方法(所有方法全为大写)有多种,各个方法的解释如下:
    	GET     请求获取Request-URI所标识的资源
    	POST    在Request-URI所标识的资源后附加新的数据
    	HEAD    请求获取由Request-URI所标识的资源的响应消息报头
    	PUT     请求服务器存储一个资源,并用Request-URI作为其标识
    	DELETE  请求服务器删除Request-URI所标识的资源
    	TRACE   请求服务器回送收到的请求信息,主要用于测试或诊断
    	CONNECT 保留将来使用
    	OPTIONS 请求查询服务器的性能,或者查询与资源相关的选项和需求
    应用举例:
    	GET方法:在浏览器的地址栏中输入网址的方式访问网页时,
    	浏览器采用GET方法向服务器获取资源,
    	eg:GET /form.html HTTP/1.1 (CRLF)
    
    	POST方法要求被请求服务器接受附在请求后面的数据,常用于提交表单。
    	eg:POST /reg.jsp HTTP/ (CRLF)
    	Accept:image/gif,image/x-xbit,... (CRLF)
    	...
    	HOST:www.guet.edu.cn (CRLF)
    	Content-Length:22 (CRLF)
    	Connection:Keep-Alive (CRLF)
    	Cache-Control:no-cache (CRLF)
    	(CRLF)         //该CRLF表示消息报头已经结束,在此之前为消息报头
    	user=jeffrey&pwd=1234  //此行以下为提交的数据
    
    	HEAD方法与GET方法几乎是一样的;
    	对于HEAD请求的回应部分来说,它的HTTP头部中包含的信息与通过GET请求所得到的信息是相同的。
    	利用这个方法,不必传输整个资源内容,就可以得到Request-URI所标识的资源的信息。
    	该方法常用于测试超链接的有效性,是否可以访问,以及最近是否更新。
    
    
     
    
    HTTP协议详解之响应篇
    
        在接收和解释请求消息后,服务器返回一个HTTP响应消息。
        HTTP响应也是由三个部分组成,分别是:状态行、消息报头、响应正文
    
    1、状态行格式如下:HTTP-Version Status-Code Reason-Phrase CRLF
    	HTTP-Version表示服务器HTTP协议的版本;
    	Status-Code表示服务器发回的响应状态代码;
    	Reason-Phrase表示状态代码的文本描述。
    
    状态代码有三位数字组成,第一个数字定义了响应的类别,且有五种可能取值:
    	1xx:指示信息--表示请求已接收,继续处理
    	2xx:成功--表示请求已被成功接收、理解、接受
    	3xx:重定向--要完成请求必须进行更进一步的操作
    	4xx:客户端错误--请求有语法错误或请求无法实现
    	5xx:服务器端错误--服务器未能实现合法的请求
    
    常见状态代码、状态描述、说明:
    	200 OK      //客户端请求成功
    	400 Bad Request  //客户端请求有语法错误,不能被服务器所理解
    	401 Unauthorized //请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用 
    	403 Forbidden  //服务器收到请求,但是拒绝提供服务
    	404 Not Found  //请求资源不存在,eg:输入了错误的URL
    	500 Internal Server Error //服务器发生不可预期的错误
    	503 Server Unavailable  //服务器当前不能处理客户端的请求,一段时间后可能恢复正常

      - 不遵循http协议的response

    import socket
    
    def main():
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        sock.bind(('localhost',8090))
        sock.listen(5)
    
        while True:
            print("server is working.....")
            conn, address = sock.accept()
            request = conn.recv(1024)
            print(request.decode('utf-8'))
            # 只返回一个字符串
            conn.sendall(bytes("Hello standby"))
            conn.close()
    
    if __name__ == '__main__':
        main()
    
    ---server端崩了---
    server is working.....
    Traceback (most recent call last):
      File "D:/soft/work/Python_17/day12/coding01.py", line 24, in <module>
        main()
      File "D:/soft/work/Python_17/day12/coding01.py", line 18, in main
        conn.sendall(bytes("Hello standby"))
    TypeError: string argument without an encoding
    GET / HTTP/1.1
    Host: 127.0.0.1:8090
    Connection: keep-alive
    Cache-Control: max-age=0
    Upgrade-Insecure-Requests: 1
    User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36
    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
    Accept-Encoding: gzip, deflate, br
    Accept-Language: zh-CN,zh;q=0.8

      - 遵循http协议的response

    import socket
    
    def main():
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        sock.bind(('localhost',8090))
        sock.listen(5)
    
        while True:
            print("server is working.....")
            conn, address = sock.accept()
            request = conn.recv(1024)
            print(request.decode('utf-8'))
            # 必须按照http协议定义好的规则进行response才可以(有响应头和响应体并且要换行...)
            conn.sendall(bytes("HTTP/1.1 200 OK
    
    <h1>Hello standby</h1>","utf8"))
            conn.close()
    
    if __name__ == '__main__':
        main()
    
    ---在浏览器打开:http://127.0.0.1:8090/---
    页面输出结果:
    Hello standby
    
    server端输出结构:
    server is working.....
    GET / HTTP/1.1
    Host: 127.0.0.1:8090
    Connection: keep-alive
    Cache-Control: max-age=0
    Upgrade-Insecure-Requests: 1
    User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36
    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
    Accept-Encoding: gzip, deflate, br
    Accept-Language: zh-CN,zh;q=0.8
    
    
    server is working.....
    GET /favicon.ico HTTP/1.1
    Host: 127.0.0.1:8090
    Connection: keep-alive
    Pragma: no-cache
    Cache-Control: no-cache
    User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36
    Accept: image/webp,image/apng,image/*,*/*;q=0.8
    Referer: http://127.0.0.1:8090/
    Accept-Encoding: gzip, deflate, br
    Accept-Language: zh-CN,zh;q=0.8
    
    
    server is working.....
    # 把文件的内容读出来作为响应体返回给浏览器
    
    # index.html
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
    
        <meta name="keywords" content="xxx">
        <meta name="description" content="miaosu">
        <title>standby</title>
    </head>
    <body>
        <h1>Hello standby666</h1>
    </body>
    </html>
    
    
    # 执行文件
    import socket
    
    def main():
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        sock.bind(('localhost',8080))
        sock.listen(5)
        while True:
            print("server is working.....")
            conn, address = sock.accept()
            request = conn.recv(1024)
            print(request.decode('utf-8'))
            f = open('index.html',mode='r',encoding='utf-8')
            ret = f.read()
            conn.sendall(bytes("HTTP/1.1 200 OK
    
    {}".format(ret),"utf8"))
            conn.close()
    
    if __name__ == '__main__':
        main()
    
    ---结果---
    server is working.....
    GET / HTTP/1.1
    Host: 127.0.0.1:8080
    Connection: keep-alive
    Upgrade-Insecure-Requests: 1
    User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36
    Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
    Accept-Encoding: gzip, deflate, br
    Accept-Language: zh-CN,zh;q=0.8
    
    
    server is working.....
    GET /favicon.ico HTTP/1.1
    Host: 127.0.0.1:8080
    Connection: keep-alive
    User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36
    Accept: image/webp,image/apng,image/*,*/*;q=0.8
    Referer: http://127.0.0.1:8080/
    Accept-Encoding: gzip, deflate, br
    Accept-Language: zh-CN,zh;q=0.8
    
    
    server is working.....
    

    一、HTML

    参考:http://www.cnblogs.com/yuanchenqi/articles/6835654.html

      1.简单介绍

    超文本标记语言(Hypertext Markup Language,HTML)通过标签语言来标记要显示的网页中的各个部分。一套规则,浏览器认识的规则;
    
    浏览器按顺序渲染网页文件,然后根据标记符解释和显示内容。
    但需要注意的是,对于不同的浏览器,对同一标签可能会有不完全相同的解释(兼容性)
    
    静态网页文件扩展名:.html 或 .htm;
    # HTML格式
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <!--文件头-->
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
        <!--文件体-->
    </body>
    </html>
    标签属性
        闭合标签
        自闭和标签
    
    
    标签分类
        块级标签,自己独占一行,例如 hn(1~6),<p>,<div></div>>...
        内联标签,所占大小取决于内容
    
    
        块级标签可以嵌套块级/内联标签
        内联标签只能嵌套内联标签

      2.<!DOCTYPE>标签

    <!DOCTYPE> 声明位于文档中的最前面的位置,处于 <html> 标签之前。
    此标签可告知浏览器文档使用哪种 HTML 或 XHTML 规范。
    
    作用:声明文档的解析类型(document.compatMode),避免浏览器的怪异模式。
    
    
    document.compatMode:
    BackCompat:怪异模式,浏览器使用自己的怪异模式解析渲染页面。
    CSS1Compat:标准模式,浏览器使用W3C的标准解析渲染页面。
    
    这个属性会被浏览器识别并使用,
    但是如果你的页面没有DOCTYPE的声明,那么compatMode默认就是BackCompat;

      3.<head>内常用标签

      4.<body>内常用标签

        - 基本标签

        - div和span标签

        - img图形标签

        - 超链接标签

        - 列表标签(有序、无序、自定义)

        - 表格标签

        - form表单标签

        - input系列标签

        - select标签

        - textarea多行文本标签

        - label标签

        - fieldset标签

    二、CSS

    参考:http://www.cnblogs.com/yuanchenqi/articles/6856399.html

    一个页面主最本的元素就是 HTML的标签
    
    css 就是着装和布局
    
    js  所有的动态操作实现动态效果
    
    # a标签不显示下划线
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            a {
                font-size: 100px;
                text-decoration: none; /*去掉a标签的下划线*/
            }
            a:active {
                color: mediumvioletred;
            }
        </style>
    </head>
    <body>
    <a href="">click</a>
    </body>
    </html>
    
    
    # img标签居中显示
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            .box {
                 100%;
                height: 650px;
                /*background-color: wheat;*/
                background-image: url("tsl.jpg");
                background-repeat: no-repeat;
                /*background-repeat: repeat-x;*/
                /*background-position: 100px 100px;*/
                background-position: center center;
            }
        </style>
    </head>
    <body>
    <div class="box">
    </div>
    </body>
    </html>
    

      

    三、练习

    要求:

    1.实现一个登陆页面,如下:

    代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            .box{
                border: 1px solid darkgray;
                 80%;
                height: 440px;
                text-align: center;
                margin: 0 auto;
                /*background-color: wheat;*/
            }
            #pic1{
                margin-top: 20px;
                margin-left: 140px;
                margin-bottom: 30px;
            }
            .left_box{
                float: left;
                background-color: wheat;
                margin: 0 auto;
                height: 440px;
                 50%;
            }
            .right_box{
                float: right;
                background-color: darkgray;
                height: 439px;
                 50%;
                /*border:1px blue solid;*/
            }
            #pic2{
                height: 400px;
                padding-left: -10px;
                padding-right: 25px;
                /*margin: 0 auto;*/
                padding-top: 20px;
                /*vertical-align: middle;*/
            }
            .right_box_inner{
                margin-top: 30px;
                height: 400px;
                padding-top: 50px;
                padding-right: 80px;
            }
            .right_box_inner > p > .btn1{
                background-color: red;
                border: none;
                color: white;
                text-align: center;
                font-size: 16px;
                padding: 10px 100px;
                border-radius: 4px;
                margin-right: -50px;
                 290px;
            }
            .right_box_inner > p > .btn2{
                background-color: green;
                border: none;
                color: white;
                text-align: center;
                font-size: 20px;
                padding: 10px 2px;
                margin-right: -500px;
                 120px;
                margin-top: 5px;
            }
            .pass{
                margin-top: 30px;
                margin-bottom: 30px;
            }
            .forget_pass{
                margin-top: 30px;
                margin-bottom: 30px;
                margin-right: 75px;
            }
            .right_box_inner > p > input{
                 270px;
                border: 1px solid #ccc;
                padding: 7px 10px;
                border-radius: 3px; /*css3属性IE不支持*/
                /*padding-left:5px;*/
            }
            .right_box_inner > p > input[name=auth_code]{
                 100px;
            }
            .input_3{
                padding-right: 185px;
            }
            .footer{
                text-align: center;
                color: darkgray;
            }
        </style>
    </head>
    <body>
    
    <img id="pic1" src="img/mll_logo.gif" alt="美乐乐首页图表">
    
    <div class="box">
        <div class="left_box">
            <a href="http://www.cnblogs.com/standby/" target="_blank">
                <img id="pic2" src="img/login_logo.png" alt="发羊财图片" title="点击有惊喜">
            </a>
        </div>
        <div class="right_box">
            <div class="right_box_inner">
                <p>
                    <label for="user_name">姓名:</label>
                    <input type="text" name="user_name" id="user_name" placeholder="请输入姓名" size="22">
                </p>
                <p class="pass">
                    <label for="user_pass">密码:</label>
                    <input type="password" name="user_pass" id="user_pass" placeholder="请输入密码" size="22">
                </p>
                <p class="input_3">
                    <label for="auth_code">验证码:</label>
                    <input type="text" name="auth_code" id="auth_code">
                </p>
                <p class="forget_pass">
                    <span>
                        <input type="checkbox" name="auto_login" value="auto_login" checked="checked">自动登录
                        <a href="http://www.cnblogs.com/standby/" target="_blank">忘记密码?</a>
                    </span>
                </p>
                <P>
                    <input class="btn1" type="button" name="btn1" value="登录">
                </P>
                <p>
                    <input class="btn2" type="button" name="btn2" value="免费注册>>">
                </p>
            </div>
    
        </div>
    </div>
    <div class="footer">
        <p>
            © http://www.cnblogs.com/standby/ ®谢绝转载!
        </p>
    </div>
    </body>
    </html>

    效果:

    2.实现一个注册页面,如下:

     

    代码实现:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            .box{
                border: 1px solid darkgray;
                 74%;
                height: 420px;
                text-align: center;
                margin: 0 auto;
                /*background-color: wheat;*/
            }
            .nav {
                background-color: #53e3a6;
                text-align: center;
                line-height: 20px;
                position: fixed;
                top: 0;
                left: 10%;
                 80%;
                height: 40px;
                padding-bottom: 10px;
                z-index: 99;
            }
            .nav li a:hover{
                background: yellowgreen;
            }
            .nav_left > li {
                display: inline;
                float: left;
                margin-left: 150px;
            }
            .nav_right {
                margin-right: 150px;
            }
            .nav_right > li {
                display: inline;
                float: right;
                margin-right: 30px;
            }
            .pic1 {
                /*margin-top: 15px;*/
                margin-top: 60px;
                margin-left: 180px;
                margin-bottom: 15px;
            }
            .body_left {
                float: left;
                margin: 0 auto;
                height: 420px;
                 50%;
                /*background-color: wheat;*/
            }
            .body_between {
                float: left;
                 15%;
                height: 420px;
                /*background-color: yellowgreen;*/
            }
            #hr_line {
                float: right;
                margin-top: 50px;
                 1px;
                height: 320px;
                background-color: #53e3a6;
            }
            .body_right {
                float: right;
                margin: 0 auto;
                height: 420px;
                 35%;
                /*background-color: #53e3a6;*/
                /*border-left: 1px solid darkgray;*/
            }
            .body_left > p > input {
                 270px;
                border: 1px solid #ccc;
                padding: 7px 10px;
                border-radius: 3px; /*css3属性IE不支持*/
                /*border-left: 10px solid red;*/
                /*padding-left:5px;*/
            }
            .new_register {
                margin-right: 300px;
            }
            .pass1,.pass2 {
                margin-left: -16px;
            }
            .auth_code_input {
                margin-left: -150px;
            }
            #auth_code {
                 120px;
            }
            .read_protocal {
                margin-left: 50px;
            }
            .btn1 {
                 290px;
                height:38px;
                background-color: red;
                border: none;
                color: white;
                text-align: center;
                font-size: 16px;
                border-radius: 4px;
                margin-right: -70px;
            }
            .login_direct {
                margin-top: 75px;
                margin-bottom: 20px;
            }
            .label_to_login {
                font-size: 20px;
                margin-left: -16px;
            }
            .btn_login {
                font-size: 20px;
            }
            .footer{
                text-align: center;
                color: darkgray;
            }
        </style>
    </head>
    <body>
    
        <div class="nav">
            <ul class="nav_left">
                <li><a href="">*收藏本站</a></li>
            </ul>
            <ul class="nav_right">
                <li><a href="">登录</a></li>
                <li><a href="">免费注册</a></li>
                <li><a href="">我的订单</a></li>
                <li><a href="">VIP会员俱乐部</a></li>
                <li><a href="">客户服务</a></li>
            </ul>
        </div>
        <div class="pic1">
            <a href="http://www.cnblogs.com/standby/" TARGET="_blank">
                <img id="pic1" src="img/mll_logo.gif" alt="美乐乐首页图表" title="跳转到首页">
            </a>
        </div>
        <div class="box">
            <div class="body_left">
                <h2><label for="user_name" class="new_register">注册新用户</label></h2>
                <p>
                    <label for="user_name">用户名:</label>
                    <input type="text" name="user_name" id="user_name" placeholder="请输入姓名" size="22">
                </p>
                <p>
                    <label for="user_tel">手机号:</label>
                    <input type="text" name="user_tel" id="user_tel" placeholder="请输入手机号" size="22">
                </p>
                <p class="pass1">
                    <label for="user_pass1">登录密码:</label>
                    <input type="password" name="user_pass1" id="user_pass1" placeholder="请输入密码" size="22">
                </p>
                <p class="pass2">
                    <label for="user_pass2">确认密码:</label>
                    <input type="password" name="user_pass2" id="user_pass2" placeholder="请确认密码" size="22">
                </p>
                <p class="auth_code_input">
                    <label for="auth_code">验证码:</label>
                    <input type="text" name="auth_code" id="auth_code">
                </p>
    
                <p class="read_protocal">
                    <span>
                        <input id="check_box" type="checkbox" name="auto_login" value="read_protocal" checked="checked">我已阅读并同意
                        <a id="readed" href="http://www.cnblogs.com/standby/" target="_blank">《新用户注册协议》</a>
                    </span>
                </p>
                <input class="btn1" type="button" name="btn1" value="同意以上协议并注册">
            </div>
            <div class="body_between">
                <hr id="hr_line">
            </div>
            <div class="body_right">
                <p class="login_direct">
                    <span>
                        <label class="label_to_login" for="">我已经注册,现在就</label>
                        <a href="http://www.cnblogs.com/standby/" class="btn_login" target="_blank">登录</a>
                    </span>
                </p>
                <a href="http://www.cnblogs.com/standby/" TARGET="_blank">
                    <img id="pic2" src="img/hongbao.jpg" alt="抢红包" title="点击进行红包大战">
                </a>
            </div>
        </div>
        <div class="footer">
            <p>
                © http://www.cnblogs.com/standby/ ®谢绝转载!
            </p>
        </div>
    </body>
    </html>
    

      

    效果:

    作者:Standby一生热爱名山大川、草原沙漠,还有妹子
    出处:http://www.cnblogs.com/standby/

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    实验 3:Mininet 实验——测量路径的损耗率
    2020福州大学软件工程实践个人编程作业
    实验 2:Mininet 实验——拓扑的命令脚本生成
    实验 7:OpenDaylight 实验——Python 中的 REST API 调用
    第4次作业-结对编程之实验室程序实现
    实验 6:OpenDaylight 实验——OpenDaylight 及 Postman 实现流表下发
    实验 5:OpenFlow 协议分析和 OpenDaylight 安装
    福州大学软件工程实践结对编程作业(需求分析与原型设计)
    实验 4:Open vSwitch 实验——Mininet 中使用 OVS 命令
    实验 3:Mininet 实验——测量路径的损耗率
  • 原文地址:https://www.cnblogs.com/standby/p/7195935.html
Copyright © 2011-2022 走看看