前端开发之html篇

一、什么是html?

  1.我们说socket网络编程的时候,提到过一个cs模型,就是客户端—服务端模型,前端开发也是基于网络编程,但是这时就应该是bs模型了,是浏览器与服务端的通信。

  我们可以模拟一个bs模型:

  

#服务端
import socket

sock=socket.socket()
sock.bind(('127.0.0.1',8989))
#绑定ip和端口
sock.listen(5)

while True:
    conn,addr=sock.accept()
    print('conn',conn)
    print('addr',addr)
    data=conn.recv(1024)
    print(data.decode('utf8'))

我们会在服务端收到这样一些东西

conn <socket.socket fd=444, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('127.0.0.1', 8989), raddr=('127.0.0.1', 61502)>
addr ('127.0.0.1', 61502)
GET / HTTP/1.1
Accept: text/html, application/xhtml+xml, image/jxr, */*
Accept-Language: zh-CN
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.116 Safari/537.36 Edge/15.15063
Accept-Encoding: gzip, deflate
Host: 127.0.0.1:8989
Connection: Keep-Alive

这些就是http的请求头,浏览器会把这些请求以键值对的方式发送给服务端

  2.html全称叫超文本标记语言(Hypertext Markup Language),是一种标记语言,通过标签来识别和描述网页中的结构和内容

二、html结构

  1.html的结构如下:

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="x-ua-compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>Title</title>
    </head>
    
    <body>
    
    </body>
</html>

 <!DOCTYPE html>是用来告诉浏览器使用什么样的html来解析html文档,不指定的话默认按照怪异模式(BackCompat),还有一个作用是指定了这个html文档的版本是html5

<html lang="en"> 是 表明当前标签下使用的语言是英文

<html></html> 是文档的开始和结束标记,作用是告诉浏览器这是一个html文档

<head></head> 是网页的源信息,是给计算机看得内容 

  <meta>标签可以提供页面的元信息,有name和http-equiv两个属性

    name属性:用于描述网页,属性值为content,content中的内容包括用于搜索的关键字和描述信息

    http-equiv属性:可以向浏览器传回一些信息,来帮助正确的显示网页内容

  <title></title>是既能给计算机看,又能给人看的内容,就是网页的标题,在浏览器标题栏显示

  <link rel="icon" href="url">是浏览器标题栏中显示的网页的图标

<body></body> 就是可见的网页主体的内容

三、html常用标签

  1.html标签格式:

    (1)标签由尖括号包围着关键词组成

    (2)标签通常是成对出现的,叫闭合标签,如<div></div>,不成对出现的叫自闭和标签,如<img>

    (3)标签可以带属性,也可以不带属性

    (4)标签可以嵌套,但是要结构分明,不能交叉嵌套

    (5)块级标签可以嵌套块级标签和内联标签,但是内联标签只能嵌套内联标签

    (6)标签不区分大小写,推荐使用小写

    (7)在代码中的空格,不论写几个,都会默认是一个,可以用特殊字符表示多个空格(&nbsp)

  2.块级标签和内联标签

    块级标签就是这个标签里的内容独占一行,后面的内容只能另起一行显示,典型的如div标签

    而内联标签是指按文本内容占位置,典型的如span标签

  3.基本标签

    <b>zhang</b>加粗标签
    <br>换行
    <em>zhang</em>斜体
    <h2>zhang</h2>hn,从1到6,字体依次变小,用来表示标题
    <hr>插入一条水平线
    2<sub>3</sub>上角标
    3<sup>2</sup>下角标
    <strike>zhang</strike>删除线
    <strong>zhang</strong>加粗,作用同b标签
    &nbsp 表示空格
    <div></div>本身无特殊格式,只是定义了一个块级元素
    <span></span>同span,本身无特殊格式,定义一个行内元素
  4.img标签:图片标签   内联标签
     
        <img src="url" alt="图片" title="图片" width="300px" height="600px">

    src:图片路径

    alt:图片加载失败时的提示信息

    title:鼠标悬浮在图片上的信息

    width:图片宽度

    height:图片高度

  5.超链接标签  a  内联标签

    <a href="url" target="_blank">点击</a>

    href:要链接到的地址,如果是#,表示为空地址

    target="_blank":表示重新打开一个新的网页,当前网页不变

   a标签还可以用来实现锚的功能

    比如在body开头位置加一个div标签,id设为“start”,这样在后面不管什么地方加上<a href="#start">返回顶部</a>,在网页中点击这个“返回顶部”,就可以实现返回网页顶部的功能了。

  6. 列表标签   块级标签

    当我们的html有很多并列的元素时,可以把这些并列的元素都放在列表中

    列表标签包括三种:ul无序列表,ol有序列表和dl自定义列表,常用的是无序列表

    <ul> 与 <li> 连用,<li> 下面是列表的每一项

    <dl> 自定义列表

       <dt> 列表标题

       <dd> 列表项

  7.表格标签   table  块级标签

    主要用来显示表格类数据,其中tr表示行,td或者th表示列,th是标题样式

    基本结构为

    <table>

      <tr>

        <th>标题<th>
        <th>标题<th>
      </tr>

      <tr>

        <td>内容<td>
        <td>内容<td>
      </tr>

    属性有:

      

<table border="1px" cellpadding="2px" cellspacing="2px" width="300px">
            border:表格边框
            cellspacing: 外边距
            cellpadding: 内边距
            width: 表格宽度,像素或者百分比
            
            <tr>
                <td rowspan="3">111</td>
                    rowspan: 单元格竖跨几个格
                <td colspan="2">222</td>
                    colspan: 单元格横跨几个格
            </tr>
        </table>

练习:写一个课程表

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="x-ua-compatible" content="IE=chrome">
 6     <meta name="viewport" content="width=device-width, initial-scale=1">
 7     <title>class schedule</title>
 8 </head>
 9     <body>
10         <table border="1">
11             <strong>
12                 <caption>课程表</caption>
13             </strong>
14         
15         
16             <tr>
17                 <th>项目</th>
18                 <th colspan="5">上课</th>
19                 <th colspan="2">休息</th>
20             </tr>
21         
22             <tr>
23                 <th>星期</th>
24                 <th>星期一</th>
25                 <th>星期二</th>
26                 <th>星期三</th>
27                 <th>星期四</th>
28                 <th>星期五</th>
29                 <th>星期六</th>
30                 <th>星期日</th>
31             </tr>
32         
33             <tr>
34                 <td rowspan="4">上午</td>
35                 <td>语文</td>
36                 <td>数学</td>
37                 <td>英语</td>
38                 <td>英语</td>
39                 <td>物理</td>
40                 <td>计算机</td>
41                 <td rowspan="4">休息</td>
42             </tr>
43         
44             <tr>
45                 <td>数学</td>
46                 <td>数学</td>
47                 <td>地理</td>
48                 <td>历史</td>
49                 <td>化学</td>
50                 <td>计算机</td>
51             </tr>
52         
53             <tr>
54                 <td>化学</td>
55                 <td>语文</td>
56                 <td>体育</td>
57                 <td>计算机</td>
58                 <td>英语</td>
59                 <td>计算机</td>
60             </tr>
61         
62             <tr>
63                 <td>政治</td>
64                 <td>英语</td>
65                 <td>体育</td>
66                 <td>历史</td>
67                 <td>地理</td>
68                 <td>计算机</td>
69             </tr>
70         
71             <tr>
72                 <td rowspan="2">下午</td>
73                 <td>语文</td>
74                 <td>数学</td>
75                 <td>英语</td>
76                 <td>英语</td>
77                 <td>物理</td>
78                 <td>计算机</td>
79                 <td rowspan="2">休息</td>
80             </tr>
81         
82             <tr>
83                 <td>数学</td>
84                 <td>数学</td>
85                 <td>地理</td>
86                 <td>历史</td>
87                 <td>化学</td>
88                 <td>计算机</td>
89             </tr>
90         
91         </table>
92     </body>
93 </html>
课程表

   8.表单标签 form    

    我们在网页上见到的注册或者登陆时的那些可以输入东西的框框,就用到了表单标签。

   表单标签就是用来收集用户输入的信息,在表单标签中,最重要的就是input系列

  (1)input系列

    

<form action="">
        用户名:<input type="text" name="user" value="zhang"><br>
            <!--text表示框内输入的是文本形式,正常显示-->
        密码: <input type="password" name="pwd" value="123">
            <!--password表示框内输入的是密码,会隐藏,显示*****-->
        <input type="radio">记住密码<br>
            <!--radio表示单选框-->
        性别:<input type="radio" name="sex" value="1" checked><!--checked表示默认-->
             <input type="radio" name="sex" value="0" ><br>

        爱好:
            篮球<input type="checkbox" name="hobby" checked>
                <!--check表示是默认值-->
            足球<input type="checkbox" name="hobby">
            羽毛球<input type="checkbox" name="hobby">
        <!--checkbox 表示复选框-->
        <br>
        <input type="submit" value="提交">
        <!--提交按钮-->
        <br>
        <input type="reset">
        <!--重置按钮-->
        <br>
        <input type="file">
        <!--选择文件按钮-->
        
        表单标签最重要的功能是实现前端和服务器端的通信,
        我们在input框里输入的东西,怎么传给服务器端呢,
        就是通过我们在input里面指定的name和value
        我们输入的信息会以键值对的形式发送给服务器端,
        name就是key ,value就是对应的值,
        但是submit那个value不一样,那是显示的名字
    </form>

上面的代码在浏览器中大概就是这样子的:

先忽略“丑”这个问题,我们将会在css中解决这个问题

  input里面还有一个属性,placeholder,这个是提示用的,看效果:

<input type="text" placeholder="用户名">

  input还有一个disable属性,设置这个属性后输入框将不能使用  

  (2)select标签,这个是实现下拉菜单的,比如选择一个省份,点一个三角就把所有省份罗列出来    

籍贯:<select name="jiguan" id="">
                <option value="hebei">河北省</option>
                <option value="henan">河南省</option>
                <option value="shandong">山东省</option>
                <option value="jiangxi">江西省</option>
                <option value="beijing">北京市</option>
            </select>

就是这个效果,那能不能有默认值呢,能不能多选呢,可以的

multiple属性就表示多选,size表示选几个,selected表示默认值

籍贯:<select name="jiguan" id="" multiple="multiple" size="2">
                <option value="hebei">河北省</option>
                <option value="henan">河南省</option>
                <option value="shandong" selected>山东省</option>
                <option value="jiangxi">江西省</option>
                <option value="beijing">北京市</option>
            </select>

(3)多行文本框标签 textarea

  <textarea name="jianjie" cols="30" rows="10"></textarea>

  可以指定行数和列数

(4)label标签

  这个标签的效果就是需要在输入框输入东西的时候,鼠标不一定要点在框内,在前面的“用户名”位置也可以快速把光标定位到输入框内

  这时需要用到id属性,每个标签都可以指定一个id属性,那这个标签在整个文档中就是独一无二的了  

<label for="user">用户名:</label>
        <input type="text" id="user">

 

 

学习前端需要学习三部分,html,css和js,html最基础,也最简单吧,话总不能说一半啊

    

  
  
    

 

    
    

    

posted @ 2017-08-07 17:30  张璨  阅读(537)  评论(0编辑  收藏  举报