zoukankan      html  css  js  c++  java
  • html

    HTML介绍

    (注:本人只是对前端简单的介绍,而且也只是达到会用的水平,前端工作者勿吐槽)

    本文是前端部分的第一篇,在开始介绍html之前先做一些简单的说明

    前端概述

    首先我们需要了解什么是前端。简单来说,前端就是网站的前台部分。这里顺便介绍一下C/S和B/S结构。

    C/S又称Client/Server或客户/服务器模式。服务器通常采用高性能的PC、工作站或小型机,并采用大型数据库系统,如Oracle、Sybase、Informix或 SQL Server。客户端需要安装专用的客户端软件。这个客户端软件就是上面提到的前端部分。
    B/S是Brower/Server的缩写,客户机上只要安装一个浏览器(Browser),如Netscape Navigator或Internet Explorer,服务器安装Oracle、Sybase、Informix或 SQL Server等数据库。浏览器通过Web Server 同数据库进行数据交互。这里的前端部分则是指浏览器。

    两者比较一下:C/S模式响应快,但是需要安装软件,而B/S模式只需要有浏览器就可以和服务器之间进行交互。本文介绍的也就是有关B/S模式中前端部分的内容。

    html、css、js的关系

    如果把一个网页当成一场皮影戏的话,这场皮影戏对应的四个部分:舞台、皮革、皮革上的色彩、皮影的动作就分别对应浏览器、html、css和js

    浏览器是一个舞台;

    html相当于一个模板;

    css则是给这个模板进行渲染;

    js则是让这个网页动起来。

    html学习

    啰嗦了一大堆,现在开始正式的html介绍

    html是什么

    html的全拼是htyper text markup language ,即超文本标记语言

    普通文本只能包括文字,而超文本则指的是可以包括图片、链接甚至音乐、程序等非文字的元素。

    如果详细的看浏览器和服务器之间传输的数据的话,只是一串字符串,而浏览器的作用就是将这一串字符串变成一个展示给用户的网页。

    标签是什么

    直观上看是由一对尖括号括住的单词,如<html>

    标签也是不区分大小写的,但是推荐使用小写

    标签分为两种:

      普通标签:分为两个部分:开始标签和结束标签,如<html></html>,结束部分一般用“/”标识,而两个标签中间的部分称之为标签体

      自闭和标签:功能比较单一的使用一个标签即可,如:<br/、<hr/>等

    注意标签使用的时候不可以交叉嵌套,如:<a><b></a></b>

    标签的属性

    通常以键值对的形式出现在开始标签或者自闭标签中,如:name="name"

    注:

    1、属性名全部小写

    2、属性值要用双引号括起来

    3、属性名和属性值完全一样的时候,直接写属性名,如:checked

    常用标签介绍

    <!DOCTYPE html>标签介绍

    由于历史原因,在W3C标准出台以前,浏览器对页面的渲染没有统一的规范。这个标签是为了表示是按照w3c标准写的,如果不写,表示用的怪异模式,即用自己的怪异模式来解析渲染页面,这样平时可能不会暴露问题,但是在一些情况下会暴露出来。详细的情况这里就不多介绍了,这里这个只做了解。

    <head>标签

     

    <head>
        
        <meta name="keywords" content="学校,廊坊,师范,廊坊师范">                  <!--搜索引擎关键字-->
         <meta http-equiv="Refresh" content="2;URL=https://www.baidu.com">        <!--两秒后跳转到目标地址,没有目标地址就是刷新本页面 -->
        <meta http-equiv="content-Type" charset="utf-8">                        <!--设置编码格式-->
        <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7">                <!--兼容IE规范-->
        <title>Document</title>                                                    <!--网页的名字-->
        <link rel="stylesheet" type="text/css" href="css.css">                    <!--引入css文件-->
        <link rel="icon" href="http://www.jd.com/favicon.ico">                    <!--标签上的图标设置,本地图片和网络的都可以-->
        <script></script>                                                  <!--用于写入js代码-->
        <style></style>                                                      <!--用于写入css代码-->
        <script src="Hello.js"></script>                                        <!--引入js文件-->
    </head>

    上面是head中常用的标签和对应的注释。

    既然说到注释这个问题,这里就把html中常用的注释说明一下:

    注释:<!--注释内容 -->

    标签分类

    标签分为块级标签和内联标签

    块级(block)标签的特点:

      总是在新行开始

      宽度缺省则是占容器的的100%

      可以容纳其他块级标签和内联标签

    常见的块级标签:<p>、<h1>、<table>、<ol>、<ul>、<form>、<div>

    内联(inline)标签特点:

      不另开一行

      宽度就是文字或者图片的宽度,不可改变

      只能容纳文本或者其他内联标签

    常见的内联标签:<a>、<input>、<img>、<sub>、<sup>、<textarea>、<span>

    基本标签

    <hn>: n的取值范围是1~6; 从大到小. 用来表示标题.
    
    <p>: 段落标签. 包裹的内容会换行.并且也与上下内容之间有一行空白.
    
    <b>、<strong>: 加粗标签.
    
    <em>: 文字变成斜体.
    
    <sup>和<sub>: 上角标 和 下角标.
    
    <br>:换行.
    
    <hr>:显示一条水平线
    
    

    含样式和语义的标签

            1、em标签,行内元素,表示语气中的强调词
            2、i标签,行内元素,w3c强加了语义,表示专业词汇
            3、b标签,行内元素,w3c强加了语义,表示文档中的关键字或者产品名
            4、strong标签,行内标签,表示非常重要的内容
            注:语义化标签就是在布局的时候使用语义化标签,搜索引擎在爬网的时候能认识这些标签,理解文档的结构,方便网站收录,这些标签都是成对出现的,标记的内容会有特殊显示

    图形标签<img>

    常见属性:

    
    
      src:要显示的图片路径
      alt:图片没有加载成功时候的提示
      title:鼠标悬停时候的提示信息
      图片的宽
      height:图片的高(宽高两个属性只用一个会自动等比缩放)


    超链接标签<a>

    常见属性:

    
    
    
    
      href:要连接的资源路径。
      target:_blank 在新窗口打开,默认是_self表示改变自己。
      title:用于将鼠标悬停到超链接的时候的显示内容。
      其他用法:
        1、将img标签放到a标签中可以实现点击图片跳转界面。
        2、在href属性中写入“#”可以回到页面顶部。在href属性中写入“javascript:;”这个是点击超链接什么都不干。
        3、href="#锚点",这里的锚点是一个标签的id属性。这样设置了的a标签可以实现点击之后跳转到本页面的对应id的标签位置。
     
    列表标签

     

        <ul>    <!--无序列表-->
            <li></li>
            <li></li>
            <li></li>
        </ul>
    
        <ol>    <!--有序列表-->
            <li></li>
            <li></li>
            <li></li>
        </ol>
    
        <dl>    <!--自定义列表-->
            <dt></dt>   <!--列表头-->
            <dd></dd>   <!--列表体-->
    <dd></dd> </dl>

     表格标签<table>

    <table border="1px"><!--表格
        属性:
            border:表格属性
            cellpadding:内边距
            cellspacing:外边距
        注:<thead>和<tbody>也可以不加
        -->
            
            <thead>        
                <tr>            <!--表示一行-->
                    <th>1</th>      <!--列表表头,内容会加粗、居中-->
                    <th>2</th>
                    <th>3</th>
                </tr>
            </thead>
            <tbody>
                <tr>
                    <td rowspan="2">111</td><!--跨两行-->
                    <td>222</td>      <!--列表体内容-->
                    <td>333</td>
                </tr>
                <tr>
                    <td>111</td>
                    <td colspan="2">222</td><!--跨两列-->
                    
                </tr>
            </tbody>
        </table>

      表单标签<form>

    表单是最重要的一个标签,因为它可以用于向服务器传输数据,实现和服务器的交互

    常用属性:

      action: 表单提交到哪. 一般指向服务器端一个程序,程序接收到表单提交过来的数据(即表单元素值)作相应处理,如www.baidu.com

      method: 表单的提交方式 post/get 默认取值 就是 get

          get:提交的内容以键值对的形式放在地址栏中url后面,安全性相对较差,对提交内容的长度有限制.

          post:提交的内容不在地址栏,安全性相对较高,对提交内容的长度理论上无限制.

            get和post是最常用的,还有其他的提交方式。

    表单元素:

        <form action="127.0.0.1:8080" method="get">
            <!--单写下面的input是没有任何意义的,必须写在form中。
                属性:
                action:来将数据提交到指定地址中
                method:提交方式,post,即不在地址栏显示,get,即在地址栏显示,默认是get
            -->
            姓名:<input type="text" name="name" placeholder="请输入姓名"><!--文本框,name相当于键值-->
            <!--其他属性:
                placeholder:属性是设置文本框中提示内容
                readonly:只读
                disabled:不允许操作,感觉和只读是一样的,但是这个对所有的input都有用
            -->
            密码:<input type="passwod" name="pwd">
            爱好:音乐<input type="checkbox" name="hobby" value="music">电影<input type="checkbox" name="hobby" value="movie"><!--多选,传的时候传的是value的值-->
            性别: 男<input type="radio" name="gender" value="men" checked><input type="radio" name="gender" value="women"><!--单选,这个时候需要将name设置一致 checked表示默认选中-->
            <input type="file" name="file">
            <!--选择上传文件
            需要注意的点,这个需要在form中设置一个enctype="nultipart/form-data" 的属性,
            而且在服务器端接收的时候用的是对象.FILES来进行接收
            django中对上传文件的下载是:
            for item in req.Files:
                fileObj = req.FILES.get(item)
                f = open(fileObj.name,"wb")
                iter_file = fileObj.chunks()
                for line in iter_file:
                    f.write(line)
                f.close()
            --><select name="province"><!--下拉列表框
                其他属性:
                    multiple:可以实现列表的多个选择
                    size:可以设置列表的显示个数
            -->
                
                <option value="beijing">北京市</option>
                <option value="hebei">河北省</option>
                <option value="henan" selected="selected">河南省</option><!--selected表示默认选中-->
                <option value="shanxi">山西省</option>
            </select>
        
    
            简介:<textarea name="desc" rows="5" cols="5"></textarea>
    
            <label for="">名字</label><!--for中写入下面id和下面的input中的id一样的话,就能实现点击名字的的时候也能实现光标在文本框效果-->
            <input id="" type="text">
    
            <fieldset><!--相当于做了个简单的样式-->
                <legend>登陆吧</legend>
                <input type="text">
            </fieldset>
            <input type="submit" value="提交"><!--提交到服务端-->
            <input type="button" value="按钮"><!--没有任何操作-->
            <input type="reset" name="重置"><!--重置-->
            <!-- readonly:只读,只限于text和password
            disabled:对所有input都有用。 -->
        </form>

     表单中还需要注意的就是哪些标签需要name,哪些需要value。当要用户输入的时候,有name就可以了,如果需要进行选择的时候,则需要value值,把用户的选择转换成值,上传到服务器。


     

    欢迎转载,但请写明出处,谢谢。
  • 相关阅读:
    Spring Boot 缓存技术:Spring Boot
    Java基础之Iterable接口
    使用sqlyog连接 Mysql 出现1251错误
    IDEA更改主题插件——Material Theme UI详解
    免安装版的Mysql
    使用Nexus搭建Maven私服
    Spring之注解注入bean
    Idea springboot 配置热部署
    Spring Boot 异常处理与单元测试
    Ubuntu20.04在线安装VMware-Tools
  • 原文地址:https://www.cnblogs.com/kuxingseng95/p/8987720.html
Copyright © 2011-2022 走看看